redis-breadcrumbs 0.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/.gitignore +1 -0
- data/.rvmrc +1 -0
- data/Gemfile +3 -0
- data/README.md +36 -0
- data/Rakefile +23 -0
- data/lib/redis-breadcrumbs.rb +3 -0
- data/lib/redis-breadcrumbs/breadcrumb.rb +35 -0
- data/lib/redis-breadcrumbs/version.rb +3 -0
- data/redis-breadcrumbs.gemspec +25 -0
- data/test/breadcrumb_test.rb +40 -0
- data/test/test_helper.rb +6 -0
- metadata +128 -0
data/.gitignore
ADDED
@@ -0,0 +1 @@
|
|
1
|
+
Gemfile.lock
|
data/.rvmrc
ADDED
@@ -0,0 +1 @@
|
|
1
|
+
rvm 1.9.3@redis-breadcrumbs --create
|
data/Gemfile
ADDED
data/README.md
ADDED
@@ -0,0 +1,36 @@
|
|
1
|
+
## Redis and key tracking
|
2
|
+
|
3
|
+
Redis is a bit different than a lot of other "data stores". This also means that thinking about ownership management
|
4
|
+
is a little bit different in redis.
|
5
|
+
|
6
|
+
Typically one domain "concept" will have different relationships with multiple keys.
|
7
|
+
|
8
|
+
Take Resque for example. A individual worker in Resque interacts with the following keys:
|
9
|
+
|
10
|
+
* The worker id is a member of `resque:workers`
|
11
|
+
* It creates `resque:worker:<id>` and `resque:worker:<id>:started`
|
12
|
+
|
13
|
+
When the worker shuts down it must remove its id from `resque:workers` and delete the other two keys.
|
14
|
+
|
15
|
+
With breadcrumbs you could describe those relationships thusly:
|
16
|
+
|
17
|
+
```ruby
|
18
|
+
class WorkerBreadcrumb < Redis::Breadcrumb
|
19
|
+
owns 'resque:worker:<id>'
|
20
|
+
owns 'resque:worker:<id>:started'
|
21
|
+
|
22
|
+
member_of_set :id => 'resque:workers'
|
23
|
+
end
|
24
|
+
```
|
25
|
+
|
26
|
+
## Usage
|
27
|
+
|
28
|
+
No release yet :)
|
29
|
+
|
30
|
+
## Contributing
|
31
|
+
|
32
|
+
1. Fork it.
|
33
|
+
2. Create a branch (`git checkout -b my_awesome_branch`)
|
34
|
+
3. Commit your changes (`git commit -am "Added some magic"`)
|
35
|
+
4. Push to the branch (`git push origin my_awesome_branch`)
|
36
|
+
5. Send pull request
|
data/Rakefile
ADDED
@@ -0,0 +1,23 @@
|
|
1
|
+
require 'rubygems'
|
2
|
+
|
3
|
+
begin
|
4
|
+
require 'bundler/setup'
|
5
|
+
rescue LoadError => e
|
6
|
+
warn e.message
|
7
|
+
warn "Run `gem install bundler` to install Bundler"
|
8
|
+
exit -1
|
9
|
+
end
|
10
|
+
|
11
|
+
require 'bundler/gem_tasks'
|
12
|
+
|
13
|
+
$LOAD_PATH.unshift 'lib'
|
14
|
+
|
15
|
+
require 'rake/testtask'
|
16
|
+
|
17
|
+
Rake::TestTask.new do |test|
|
18
|
+
test.verbose = true
|
19
|
+
test.libs << "test"
|
20
|
+
test.libs << "lib"
|
21
|
+
test.test_files = FileList['test/**/*_test.rb']
|
22
|
+
end
|
23
|
+
task :default => :test
|
@@ -0,0 +1,35 @@
|
|
1
|
+
module Redis
|
2
|
+
class Breadcrumb
|
3
|
+
class << self
|
4
|
+
attr_accessor :owned_keys
|
5
|
+
|
6
|
+
def redis
|
7
|
+
@@redis
|
8
|
+
end
|
9
|
+
|
10
|
+
def redis= redis
|
11
|
+
@@redis = redis
|
12
|
+
end
|
13
|
+
|
14
|
+
def tracked_in *args
|
15
|
+
args.length > 0 ? @tracked_in = args[0] : @tracked_in
|
16
|
+
end
|
17
|
+
|
18
|
+
def owns key
|
19
|
+
(@owned_keys ||= []) << key
|
20
|
+
end
|
21
|
+
|
22
|
+
def register
|
23
|
+
@owned_keys.each do |key|
|
24
|
+
redis.sadd @tracked_in, [:del, key].to_json
|
25
|
+
end
|
26
|
+
end
|
27
|
+
|
28
|
+
def tracked_keys
|
29
|
+
redis.smembers(@tracked_in).map do |json|
|
30
|
+
JSON.parse(json)
|
31
|
+
end
|
32
|
+
end
|
33
|
+
end
|
34
|
+
end
|
35
|
+
end
|
@@ -0,0 +1,25 @@
|
|
1
|
+
# -*- encoding: utf-8 -*-
|
2
|
+
$:.push File.expand_path("../lib", __FILE__)
|
3
|
+
require "redis-breadcrumbs/version"
|
4
|
+
|
5
|
+
Gem::Specification.new do |s|
|
6
|
+
s.name = "redis-breadcrumbs"
|
7
|
+
s.version = RedisBreadcrumbs::VERSION
|
8
|
+
s.platform = Gem::Platform::RUBY
|
9
|
+
s.authors = ['Eoin Coffey']
|
10
|
+
s.email = ['ecoffey@gmail.com']
|
11
|
+
s.homepage = "https://github.com/ecoffey/redis-breadcrumbs"
|
12
|
+
s.summary = %q{A friendly DSL for tracking and cleaning up redis keys.}
|
13
|
+
|
14
|
+
s.description = %q{Inherit from Redis::Breadcrumb to get going!}
|
15
|
+
|
16
|
+
s.files = `git ls-files`.split("\n")
|
17
|
+
s.test_files = `git ls-files -- {test,spec,features}/*`.split("\n")
|
18
|
+
s.executables = `git ls-files -- bin/*`.split("\n").map{ |f| File.basename(f) }
|
19
|
+
s.require_paths = ["lib"]
|
20
|
+
|
21
|
+
s.add_development_dependency "rake", ">= 0.9.2"
|
22
|
+
s.add_development_dependency "redis", "~> 3.0.0"
|
23
|
+
s.add_development_dependency "minitest", "~> 4.3.2"
|
24
|
+
s.add_development_dependency "mock_redis", "~> 0.6"
|
25
|
+
end
|
@@ -0,0 +1,40 @@
|
|
1
|
+
require 'test_helper'
|
2
|
+
|
3
|
+
describe 'Redis::Breadcrumb' do
|
4
|
+
class TestBreadcrumb < Redis::Breadcrumb
|
5
|
+
tracked_in 'tracking_key'
|
6
|
+
|
7
|
+
owns :a_owned_key
|
8
|
+
end
|
9
|
+
|
10
|
+
before do
|
11
|
+
redis = MockRedis.new
|
12
|
+
|
13
|
+
Redis::Breadcrumb.redis = redis
|
14
|
+
end
|
15
|
+
|
16
|
+
it 'can record a key to track in' do
|
17
|
+
assert_equal 'tracking_key', TestBreadcrumb.tracked_in
|
18
|
+
end
|
19
|
+
|
20
|
+
it 'can own a key' do
|
21
|
+
assert_equal [:a_owned_key], TestBreadcrumb.owned_keys
|
22
|
+
end
|
23
|
+
|
24
|
+
it 'will register tracked keys in tracked_in' do
|
25
|
+
TestBreadcrumb.register
|
26
|
+
|
27
|
+
assert_equal 1, Redis::Breadcrumb.redis.scard(TestBreadcrumb.tracked_in)
|
28
|
+
assert_equal [["del", "a_owned_key"]], TestBreadcrumb.tracked_keys
|
29
|
+
end
|
30
|
+
|
31
|
+
it 'tracks keys for each class' do
|
32
|
+
class Test2Breadcrumb < Redis::Breadcrumb
|
33
|
+
tracked_in 'different_tracking_key'
|
34
|
+
|
35
|
+
owns :a_different_key
|
36
|
+
end
|
37
|
+
|
38
|
+
refute_equal TestBreadcrumb.owned_keys, Test2Breadcrumb.owned_keys
|
39
|
+
end
|
40
|
+
end
|
data/test/test_helper.rb
ADDED
metadata
ADDED
@@ -0,0 +1,128 @@
|
|
1
|
+
--- !ruby/object:Gem::Specification
|
2
|
+
name: redis-breadcrumbs
|
3
|
+
version: !ruby/object:Gem::Version
|
4
|
+
version: 0.0.1
|
5
|
+
prerelease:
|
6
|
+
platform: ruby
|
7
|
+
authors:
|
8
|
+
- Eoin Coffey
|
9
|
+
autorequire:
|
10
|
+
bindir: bin
|
11
|
+
cert_chain: []
|
12
|
+
date: 2012-12-19 00:00:00.000000000 Z
|
13
|
+
dependencies:
|
14
|
+
- !ruby/object:Gem::Dependency
|
15
|
+
name: rake
|
16
|
+
requirement: !ruby/object:Gem::Requirement
|
17
|
+
none: false
|
18
|
+
requirements:
|
19
|
+
- - ! '>='
|
20
|
+
- !ruby/object:Gem::Version
|
21
|
+
version: 0.9.2
|
22
|
+
type: :development
|
23
|
+
prerelease: false
|
24
|
+
version_requirements: !ruby/object:Gem::Requirement
|
25
|
+
none: false
|
26
|
+
requirements:
|
27
|
+
- - ! '>='
|
28
|
+
- !ruby/object:Gem::Version
|
29
|
+
version: 0.9.2
|
30
|
+
- !ruby/object:Gem::Dependency
|
31
|
+
name: redis
|
32
|
+
requirement: !ruby/object:Gem::Requirement
|
33
|
+
none: false
|
34
|
+
requirements:
|
35
|
+
- - ~>
|
36
|
+
- !ruby/object:Gem::Version
|
37
|
+
version: 3.0.0
|
38
|
+
type: :development
|
39
|
+
prerelease: false
|
40
|
+
version_requirements: !ruby/object:Gem::Requirement
|
41
|
+
none: false
|
42
|
+
requirements:
|
43
|
+
- - ~>
|
44
|
+
- !ruby/object:Gem::Version
|
45
|
+
version: 3.0.0
|
46
|
+
- !ruby/object:Gem::Dependency
|
47
|
+
name: minitest
|
48
|
+
requirement: !ruby/object:Gem::Requirement
|
49
|
+
none: false
|
50
|
+
requirements:
|
51
|
+
- - ~>
|
52
|
+
- !ruby/object:Gem::Version
|
53
|
+
version: 4.3.2
|
54
|
+
type: :development
|
55
|
+
prerelease: false
|
56
|
+
version_requirements: !ruby/object:Gem::Requirement
|
57
|
+
none: false
|
58
|
+
requirements:
|
59
|
+
- - ~>
|
60
|
+
- !ruby/object:Gem::Version
|
61
|
+
version: 4.3.2
|
62
|
+
- !ruby/object:Gem::Dependency
|
63
|
+
name: mock_redis
|
64
|
+
requirement: !ruby/object:Gem::Requirement
|
65
|
+
none: false
|
66
|
+
requirements:
|
67
|
+
- - ~>
|
68
|
+
- !ruby/object:Gem::Version
|
69
|
+
version: '0.6'
|
70
|
+
type: :development
|
71
|
+
prerelease: false
|
72
|
+
version_requirements: !ruby/object:Gem::Requirement
|
73
|
+
none: false
|
74
|
+
requirements:
|
75
|
+
- - ~>
|
76
|
+
- !ruby/object:Gem::Version
|
77
|
+
version: '0.6'
|
78
|
+
description: Inherit from Redis::Breadcrumb to get going!
|
79
|
+
email:
|
80
|
+
- ecoffey@gmail.com
|
81
|
+
executables: []
|
82
|
+
extensions: []
|
83
|
+
extra_rdoc_files: []
|
84
|
+
files:
|
85
|
+
- .gitignore
|
86
|
+
- .rvmrc
|
87
|
+
- Gemfile
|
88
|
+
- README.md
|
89
|
+
- Rakefile
|
90
|
+
- lib/redis-breadcrumbs.rb
|
91
|
+
- lib/redis-breadcrumbs/breadcrumb.rb
|
92
|
+
- lib/redis-breadcrumbs/version.rb
|
93
|
+
- redis-breadcrumbs.gemspec
|
94
|
+
- test/breadcrumb_test.rb
|
95
|
+
- test/test_helper.rb
|
96
|
+
homepage: https://github.com/ecoffey/redis-breadcrumbs
|
97
|
+
licenses: []
|
98
|
+
post_install_message:
|
99
|
+
rdoc_options: []
|
100
|
+
require_paths:
|
101
|
+
- lib
|
102
|
+
required_ruby_version: !ruby/object:Gem::Requirement
|
103
|
+
none: false
|
104
|
+
requirements:
|
105
|
+
- - ! '>='
|
106
|
+
- !ruby/object:Gem::Version
|
107
|
+
version: '0'
|
108
|
+
segments:
|
109
|
+
- 0
|
110
|
+
hash: 3876120171022687880
|
111
|
+
required_rubygems_version: !ruby/object:Gem::Requirement
|
112
|
+
none: false
|
113
|
+
requirements:
|
114
|
+
- - ! '>='
|
115
|
+
- !ruby/object:Gem::Version
|
116
|
+
version: '0'
|
117
|
+
segments:
|
118
|
+
- 0
|
119
|
+
hash: 3876120171022687880
|
120
|
+
requirements: []
|
121
|
+
rubyforge_project:
|
122
|
+
rubygems_version: 1.8.24
|
123
|
+
signing_key:
|
124
|
+
specification_version: 3
|
125
|
+
summary: A friendly DSL for tracking and cleaning up redis keys.
|
126
|
+
test_files:
|
127
|
+
- test/breadcrumb_test.rb
|
128
|
+
- test/test_helper.rb
|