redis_counters 1.4.0 → 1.5.0
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.
- checksums.yaml +4 -4
- data/.drone.yml +22 -0
- data/.rspec +5 -0
- data/Gemfile +0 -3
- data/README.md +1 -1
- data/dip.yml +41 -0
- data/docker-compose.development.yml +13 -0
- data/docker-compose.drone.yml +7 -0
- data/docker-compose.yml +9 -0
- data/lib/redis_counters.rb +1 -3
- data/lib/redis_counters/base_counter.rb +6 -7
- data/lib/redis_counters/clusterize_and_partitionize.rb +1 -1
- data/lib/redis_counters/hash_counter.rb +22 -8
- data/lib/redis_counters/version.rb +2 -2
- data/redis_counters.gemspec +2 -2
- data/spec/redis_counters/hash_counter_spec.rb +64 -2
- data/spec/spec_helper.rb +3 -8
- metadata +61 -49
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: a7e6d0cc5b4ca4ed565bb19a6d630460ca7f83a9
|
4
|
+
data.tar.gz: b7962325e5af14aa63f6231b9053cc8d5f020b66
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: ea9edd7ea8fbc50f901de96b70cf51ea983c5e8bc07e0017bdddb844af3b4ec0f2105996b9dd200d7c0e5021955bc017af63e3240ec97af24ff824d3d6ea9f2b
|
7
|
+
data.tar.gz: 03a615b5e096b657e5e1982e3b568167b71b463d57d820e28062dc890b6af109e717de64ab3a7e64cffca2afbc5c0a5e14d27ebe03828772a8c4d721cff680c3
|
data/.drone.yml
ADDED
@@ -0,0 +1,22 @@
|
|
1
|
+
build:
|
2
|
+
test:
|
3
|
+
image: abakpress/dind-testing
|
4
|
+
pull: true
|
5
|
+
privileged: true
|
6
|
+
volumes:
|
7
|
+
- /home/data/drone/images:/images
|
8
|
+
- /home/data/drone/gems:/bundle
|
9
|
+
environment:
|
10
|
+
- COMPOSE_FILE_EXT=drone
|
11
|
+
- POSTGRES_IMAGE_TAG=9.3-latest
|
12
|
+
- SPHINX_IMAGE_TAG=2.2-latest
|
13
|
+
commands:
|
14
|
+
- wrapdocker docker -v
|
15
|
+
|
16
|
+
- fetch-images
|
17
|
+
--image abakpress/ruby-app:$RUBY_IMAGE_TAG
|
18
|
+
--image abakpress/postgres-db:$POSTGRES_IMAGE_TAG
|
19
|
+
--image abakpress/sphinx-index:$SPHINX_IMAGE_TAG
|
20
|
+
|
21
|
+
- dip provision
|
22
|
+
- dip rspec
|
data/.rspec
ADDED
data/Gemfile
CHANGED
data/README.md
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
# RedisCounters
|
2
2
|
|
3
|
-
[](https://drone.railsc.ru/abak-press/redis_counters)
|
4
4
|
[](https://codeclimate.com/github/abak-press/redis_counters)
|
5
5
|
[](https://codeclimate.com/github/abak-press/redis_counters/coverage)
|
6
6
|
|
data/dip.yml
ADDED
@@ -0,0 +1,41 @@
|
|
1
|
+
version: '1'
|
2
|
+
|
3
|
+
environment:
|
4
|
+
DOCKER_RUBY_VERSION: 2.2
|
5
|
+
RUBY_IMAGE_TAG: 2.2-latest
|
6
|
+
COMPOSE_FILE_EXT: development
|
7
|
+
RAILS_ENV: test
|
8
|
+
|
9
|
+
compose:
|
10
|
+
files:
|
11
|
+
- docker-compose.yml
|
12
|
+
- docker-compose.${COMPOSE_FILE_EXT}.yml
|
13
|
+
|
14
|
+
interaction:
|
15
|
+
sh:
|
16
|
+
service: app
|
17
|
+
|
18
|
+
irb:
|
19
|
+
service: app
|
20
|
+
command: irb
|
21
|
+
|
22
|
+
bundle:
|
23
|
+
service: app
|
24
|
+
command: bundle
|
25
|
+
|
26
|
+
rake:
|
27
|
+
service: app
|
28
|
+
command: bundle exec rake
|
29
|
+
|
30
|
+
rspec:
|
31
|
+
service: app
|
32
|
+
command: bundle exec rspec
|
33
|
+
|
34
|
+
clean:
|
35
|
+
service: app
|
36
|
+
command: rm -f Gemfile.lock gemfiles/*.gemfile.*
|
37
|
+
|
38
|
+
provision:
|
39
|
+
- docker volume create --name bundler_data
|
40
|
+
- dip clean
|
41
|
+
- dip bundle install
|
data/docker-compose.yml
ADDED
data/lib/redis_counters.rb
CHANGED
@@ -1,4 +1,3 @@
|
|
1
|
-
# encoding: utf-8
|
2
1
|
require 'redis_counters/version'
|
3
2
|
require 'redis_counters/base_counter'
|
4
3
|
require 'redis_counters/hash_counter'
|
@@ -12,10 +11,9 @@ require 'active_support'
|
|
12
11
|
require 'active_support/core_ext'
|
13
12
|
|
14
13
|
module RedisCounters
|
15
|
-
|
16
14
|
def create_counter(redis, opts)
|
17
15
|
BaseCounter.create(redis, opts)
|
18
16
|
end
|
19
17
|
|
20
18
|
module_function :create_counter
|
21
|
-
end
|
19
|
+
end
|
@@ -1,11 +1,8 @@
|
|
1
|
-
# coding: utf-8
|
2
1
|
require 'forwardable'
|
3
2
|
require 'active_support/core_ext/class/attribute'
|
4
3
|
|
5
4
|
module RedisCounters
|
6
|
-
|
7
5
|
# Базовый класс счетчика на основе Redis.
|
8
|
-
|
9
6
|
class BaseCounter
|
10
7
|
extend Forwardable
|
11
8
|
|
@@ -22,10 +19,13 @@ module RedisCounters
|
|
22
19
|
# opts - Hash - хеш опций счетчика:
|
23
20
|
# counter_name - Symbol/String - идентификатор счетчика.
|
24
21
|
# key_delimiter - String - разделитель ключа (опционально).
|
25
|
-
# value_delimiter - String
|
22
|
+
# value_delimiter - Array[String] или String, разделитель значений. Если это массив, то первый элемент будет
|
23
|
+
# считатся новым разделителем, а второй старым. Все данные будут записываться, используя
|
24
|
+
# новый. Старый будет использоваться только для старых данных. Так что если надо сменить
|
25
|
+
# делимитр у счётчика, например с ':' на '�', то сперва надо будет установить его на ['�',
|
26
|
+
# ':'], а после дампа старых данных в БД, на '�'.
|
26
27
|
#
|
27
28
|
# Returns RedisCounters::BaseCounter.
|
28
|
-
#
|
29
29
|
def self.create(redis, opts)
|
30
30
|
counter_class = opts.fetch(:counter_class).to_s.constantize
|
31
31
|
counter_class.new(redis, opts)
|
@@ -80,5 +80,4 @@ module RedisCounters
|
|
80
80
|
|
81
81
|
def_delegator :redis, :multi, :transaction
|
82
82
|
end
|
83
|
-
|
84
|
-
end
|
83
|
+
end
|
@@ -1,11 +1,8 @@
|
|
1
|
-
# coding: utf-8
|
2
1
|
require 'redis_counters/base_counter'
|
3
2
|
require 'redis_counters/clusterize_and_partitionize'
|
4
3
|
|
5
4
|
module RedisCounters
|
6
|
-
|
7
5
|
# Счетчик на основе redis-hash, с возможностью партиционирования и кластеризации значений.
|
8
|
-
|
9
6
|
class HashCounter < BaseCounter
|
10
7
|
include ClusterizeAndPartitionize
|
11
8
|
|
@@ -24,7 +21,11 @@ module RedisCounters
|
|
24
21
|
group_params = [field_name]
|
25
22
|
end
|
26
23
|
|
27
|
-
|
24
|
+
if value_delimiter.is_a?(Array)
|
25
|
+
group_params.join(value_delimiter.first)
|
26
|
+
else
|
27
|
+
group_params.join(value_delimiter)
|
28
|
+
end
|
28
29
|
end
|
29
30
|
|
30
31
|
def field_name
|
@@ -43,12 +44,26 @@ module RedisCounters
|
|
43
44
|
# cluster - Array - листовой кластер - массив параметров однозначно идентифицирующий кластер.
|
44
45
|
# partition - Array - листовая партиция - массив параметров однозначно идентифицирующий партицию.
|
45
46
|
#
|
46
|
-
# Returns Array of
|
47
|
-
#
|
47
|
+
# Returns Array of HashWithIndifferentAccess.
|
48
48
|
def partition_data(cluster, partition)
|
49
49
|
keys = group_keys.dup.unshift(:value)
|
50
|
+
|
51
|
+
if delimiter_is_ary = value_delimiter.is_a?(Array)
|
52
|
+
new_delim, old_delim = value_delimiter
|
53
|
+
end
|
54
|
+
|
50
55
|
redis.hgetall(key(partition, cluster)).inject(Array.new) do |result, (key, value)|
|
51
|
-
values =
|
56
|
+
values = if delimiter_is_ary
|
57
|
+
if key.include?(new_delim)
|
58
|
+
key.split(new_delim, -1)
|
59
|
+
else
|
60
|
+
key.split(old_delim, -1)
|
61
|
+
end
|
62
|
+
else
|
63
|
+
key.split(value_delimiter, -1)
|
64
|
+
end
|
65
|
+
|
66
|
+
values = values.map(&:presence).unshift(format_value(value))
|
52
67
|
values.delete_at(1) unless group_keys.present?
|
53
68
|
result << Hash[keys.zip(values)].with_indifferent_access
|
54
69
|
end
|
@@ -66,5 +81,4 @@ module RedisCounters
|
|
66
81
|
@float_mode ||= options.fetch(:float_mode, false)
|
67
82
|
end
|
68
83
|
end
|
69
|
-
|
70
84
|
end
|
@@ -1,3 +1,3 @@
|
|
1
1
|
module RedisCounters
|
2
|
-
VERSION = '1.
|
3
|
-
end
|
2
|
+
VERSION = '1.5.0'.freeze
|
3
|
+
end
|
data/redis_counters.gemspec
CHANGED
@@ -16,7 +16,7 @@ Gem::Specification.new do |spec|
|
|
16
16
|
spec.test_files = spec.files.grep(%r{^(test|spec|features)/})
|
17
17
|
spec.require_paths = ['lib']
|
18
18
|
|
19
|
-
spec.add_dependency 'activesupport', '>= 3.0'
|
19
|
+
spec.add_dependency 'activesupport', '>= 3.0', '< 5'
|
20
20
|
|
21
21
|
spec.add_development_dependency 'bundler'
|
22
22
|
spec.add_development_dependency 'rake'
|
@@ -27,5 +27,5 @@ Gem::Specification.new do |spec|
|
|
27
27
|
spec.add_development_dependency 'simplecov'
|
28
28
|
spec.add_development_dependency 'cane', '>= 2.6.0'
|
29
29
|
spec.add_development_dependency 'bundler-audit'
|
30
|
-
spec.add_development_dependency '
|
30
|
+
spec.add_development_dependency 'pry-byebug'
|
31
31
|
end
|
@@ -257,7 +257,7 @@ describe RedisCounters::HashCounter do
|
|
257
257
|
it { expect(counter.data(partitions).first[:param4]).to eq '1' }
|
258
258
|
it { expect(counter.data(partitions).second[:value]).to eq 5 }
|
259
259
|
it { expect(counter.data(partitions).second[:param3]).to eq '31' }
|
260
|
-
it { expect(counter.data(partitions).second[:param4]).to eq
|
260
|
+
it { expect(counter.data(partitions).second[:param4]).to eq nil }
|
261
261
|
end
|
262
262
|
|
263
263
|
context 'when group_keys given' do
|
@@ -446,6 +446,68 @@ describe RedisCounters::HashCounter do
|
|
446
446
|
it { expect(counter.data.third[:value]).to eq 3 }
|
447
447
|
end
|
448
448
|
|
449
|
+
context 'two delimiters' do
|
450
|
+
let(:options) do
|
451
|
+
{
|
452
|
+
counter_name: :test_counter,
|
453
|
+
group_keys: [:title, :url],
|
454
|
+
partition_keys: [:date],
|
455
|
+
key_delimiter: '&',
|
456
|
+
value_delimiter: %W(\uFFFD :)
|
457
|
+
}
|
458
|
+
end
|
459
|
+
let(:partition) { {title: 'Main', url: 'http://example.com', date: '2017-04-21'} }
|
460
|
+
|
461
|
+
before { counter.increment(partition) }
|
462
|
+
|
463
|
+
it 'uses the first (new) delimiter for writing' do
|
464
|
+
expect(counter.send(:field)).to eq('Main�http://example.com')
|
465
|
+
expect(counter.data).to eq([{'value' => 1, 'title' => 'Main', 'url' => 'http://example.com'}])
|
466
|
+
end
|
467
|
+
end
|
468
|
+
|
469
|
+
context 'new delimiter added when there is data separated by the old one' do
|
470
|
+
let(:options) do
|
471
|
+
{
|
472
|
+
counter_name: :test_counter,
|
473
|
+
group_keys: [:title, :url],
|
474
|
+
partition_keys: [:date],
|
475
|
+
key_delimiter: '&',
|
476
|
+
value_delimiter: %W(\uFFFD :)
|
477
|
+
}
|
478
|
+
end
|
479
|
+
let(:partition) { {title: 'Main', url: 'http://example.com', date: '2017-04-21'} }
|
480
|
+
|
481
|
+
before do
|
482
|
+
redis.hincrbyfloat('test_counter&2017-04-21', 'Main:/about', 1.0)
|
483
|
+
end
|
484
|
+
|
485
|
+
it 'understands the old delimiter' do
|
486
|
+
expect(counter.data).to eq([{'value' => 1, 'title' => 'Main', 'url' => '/about'}])
|
487
|
+
end
|
488
|
+
end
|
489
|
+
|
490
|
+
context 'new delimiter added and there is data separated by it but contains the old delimiter' do
|
491
|
+
let(:options) do
|
492
|
+
{
|
493
|
+
counter_name: :test_counter,
|
494
|
+
group_keys: [:title, :url],
|
495
|
+
partition_keys: [:date],
|
496
|
+
key_delimiter: '&',
|
497
|
+
value_delimiter: %W(\uFFFD :)
|
498
|
+
}
|
499
|
+
end
|
500
|
+
let(:partition) { {title: 'Main', url: 'http://example.com', date: '2017-04-21'} }
|
501
|
+
|
502
|
+
before do
|
503
|
+
redis.hincrbyfloat('test_counter&2017-04-21', 'Main�http://example.com', 1.0)
|
504
|
+
end
|
505
|
+
|
506
|
+
it 'uses the new delimiter' do
|
507
|
+
expect(counter.data).to eq([{'value' => 1, 'title' => 'Main', 'url' => 'http://example.com'}])
|
508
|
+
end
|
509
|
+
end
|
510
|
+
|
449
511
|
context 'when check custom increment' do
|
450
512
|
let(:options) { {
|
451
513
|
:counter_name => :test_counter,
|
@@ -459,4 +521,4 @@ describe RedisCounters::HashCounter do
|
|
459
521
|
it { expect(redis.hexists('test_counter', 'test_field')).to be_true }
|
460
522
|
it { expect(redis.hget('test_counter', 'test_field').to_f).to be_within(0.001).of value*0.2.to_f }
|
461
523
|
end
|
462
|
-
end
|
524
|
+
end
|
data/spec/spec_helper.rb
CHANGED
@@ -1,13 +1,11 @@
|
|
1
|
-
require 'rubygems'
|
2
1
|
require 'bundler/setup'
|
3
2
|
require 'rspec'
|
4
3
|
require 'mock_redis'
|
5
4
|
require 'timecop'
|
6
|
-
|
7
5
|
require 'codeclimate-test-reporter'
|
8
|
-
CodeClimate::TestReporter.start
|
9
|
-
|
10
6
|
require 'simplecov'
|
7
|
+
require 'pry-byebug'
|
8
|
+
|
11
9
|
SimpleCov.start('test_frameworks')
|
12
10
|
|
13
11
|
require 'redis_counters'
|
@@ -18,7 +16,4 @@ Dir[File.join(support_dir, '**', '*.rb')].each { |f| require f }
|
|
18
16
|
|
19
17
|
RSpec.configure do |config|
|
20
18
|
config.backtrace_exclusion_patterns = [/lib\/rspec\/(core|expectations|matchers|mocks)/]
|
21
|
-
|
22
|
-
config.formatter = 'documentation'
|
23
|
-
config.order = 'random'
|
24
|
-
end
|
19
|
+
end
|
metadata
CHANGED
@@ -1,169 +1,175 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: redis_counters
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 1.
|
4
|
+
version: 1.5.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Artem Napolskih
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2017-07-11 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
|
-
version_requirements: !ruby/object:Gem::Requirement
|
15
|
-
requirements:
|
16
|
-
- - '>='
|
17
|
-
- !ruby/object:Gem::Version
|
18
|
-
version: '3.0'
|
19
14
|
name: activesupport
|
20
15
|
requirement: !ruby/object:Gem::Requirement
|
21
16
|
requirements:
|
22
|
-
- -
|
17
|
+
- - ">="
|
23
18
|
- !ruby/object:Gem::Version
|
24
19
|
version: '3.0'
|
20
|
+
- - "<"
|
21
|
+
- !ruby/object:Gem::Version
|
22
|
+
version: '5'
|
25
23
|
type: :runtime
|
26
24
|
prerelease: false
|
27
|
-
- !ruby/object:Gem::Dependency
|
28
25
|
version_requirements: !ruby/object:Gem::Requirement
|
29
26
|
requirements:
|
30
|
-
- -
|
27
|
+
- - ">="
|
31
28
|
- !ruby/object:Gem::Version
|
32
|
-
version: '0'
|
29
|
+
version: '3.0'
|
30
|
+
- - "<"
|
31
|
+
- !ruby/object:Gem::Version
|
32
|
+
version: '5'
|
33
|
+
- !ruby/object:Gem::Dependency
|
33
34
|
name: bundler
|
34
35
|
requirement: !ruby/object:Gem::Requirement
|
35
36
|
requirements:
|
36
|
-
- -
|
37
|
+
- - ">="
|
37
38
|
- !ruby/object:Gem::Version
|
38
39
|
version: '0'
|
39
40
|
type: :development
|
40
41
|
prerelease: false
|
41
|
-
- !ruby/object:Gem::Dependency
|
42
42
|
version_requirements: !ruby/object:Gem::Requirement
|
43
43
|
requirements:
|
44
|
-
- -
|
44
|
+
- - ">="
|
45
45
|
- !ruby/object:Gem::Version
|
46
46
|
version: '0'
|
47
|
+
- !ruby/object:Gem::Dependency
|
47
48
|
name: rake
|
48
49
|
requirement: !ruby/object:Gem::Requirement
|
49
50
|
requirements:
|
50
|
-
- -
|
51
|
+
- - ">="
|
51
52
|
- !ruby/object:Gem::Version
|
52
53
|
version: '0'
|
53
54
|
type: :development
|
54
55
|
prerelease: false
|
55
|
-
- !ruby/object:Gem::Dependency
|
56
56
|
version_requirements: !ruby/object:Gem::Requirement
|
57
57
|
requirements:
|
58
|
-
- -
|
58
|
+
- - ">="
|
59
59
|
- !ruby/object:Gem::Version
|
60
|
-
version:
|
60
|
+
version: '0'
|
61
|
+
- !ruby/object:Gem::Dependency
|
61
62
|
name: rspec
|
62
63
|
requirement: !ruby/object:Gem::Requirement
|
63
64
|
requirements:
|
64
|
-
- - ~>
|
65
|
+
- - "~>"
|
65
66
|
- !ruby/object:Gem::Version
|
66
67
|
version: 2.14.0
|
67
68
|
type: :development
|
68
69
|
prerelease: false
|
69
|
-
- !ruby/object:Gem::Dependency
|
70
70
|
version_requirements: !ruby/object:Gem::Requirement
|
71
71
|
requirements:
|
72
|
-
- -
|
72
|
+
- - "~>"
|
73
73
|
- !ruby/object:Gem::Version
|
74
|
-
version:
|
74
|
+
version: 2.14.0
|
75
|
+
- !ruby/object:Gem::Dependency
|
75
76
|
name: mock_redis
|
76
77
|
requirement: !ruby/object:Gem::Requirement
|
77
78
|
requirements:
|
78
|
-
- -
|
79
|
+
- - ">="
|
79
80
|
- !ruby/object:Gem::Version
|
80
81
|
version: '0'
|
81
82
|
type: :development
|
82
83
|
prerelease: false
|
83
|
-
- !ruby/object:Gem::Dependency
|
84
84
|
version_requirements: !ruby/object:Gem::Requirement
|
85
85
|
requirements:
|
86
|
-
- -
|
86
|
+
- - ">="
|
87
87
|
- !ruby/object:Gem::Version
|
88
88
|
version: '0'
|
89
|
+
- !ruby/object:Gem::Dependency
|
89
90
|
name: timecop
|
90
91
|
requirement: !ruby/object:Gem::Requirement
|
91
92
|
requirements:
|
92
|
-
- -
|
93
|
+
- - ">="
|
93
94
|
- !ruby/object:Gem::Version
|
94
95
|
version: '0'
|
95
96
|
type: :development
|
96
97
|
prerelease: false
|
97
|
-
- !ruby/object:Gem::Dependency
|
98
98
|
version_requirements: !ruby/object:Gem::Requirement
|
99
99
|
requirements:
|
100
|
-
- -
|
100
|
+
- - ">="
|
101
101
|
- !ruby/object:Gem::Version
|
102
|
-
version: 0
|
102
|
+
version: '0'
|
103
|
+
- !ruby/object:Gem::Dependency
|
103
104
|
name: codeclimate-test-reporter
|
104
105
|
requirement: !ruby/object:Gem::Requirement
|
105
106
|
requirements:
|
106
|
-
- -
|
107
|
+
- - ">="
|
107
108
|
- !ruby/object:Gem::Version
|
108
109
|
version: 0.4.1
|
109
110
|
type: :development
|
110
111
|
prerelease: false
|
111
|
-
- !ruby/object:Gem::Dependency
|
112
112
|
version_requirements: !ruby/object:Gem::Requirement
|
113
113
|
requirements:
|
114
|
-
- -
|
114
|
+
- - ">="
|
115
115
|
- !ruby/object:Gem::Version
|
116
|
-
version:
|
116
|
+
version: 0.4.1
|
117
|
+
- !ruby/object:Gem::Dependency
|
117
118
|
name: simplecov
|
118
119
|
requirement: !ruby/object:Gem::Requirement
|
119
120
|
requirements:
|
120
|
-
- -
|
121
|
+
- - ">="
|
121
122
|
- !ruby/object:Gem::Version
|
122
123
|
version: '0'
|
123
124
|
type: :development
|
124
125
|
prerelease: false
|
125
|
-
- !ruby/object:Gem::Dependency
|
126
126
|
version_requirements: !ruby/object:Gem::Requirement
|
127
127
|
requirements:
|
128
|
-
- -
|
128
|
+
- - ">="
|
129
129
|
- !ruby/object:Gem::Version
|
130
|
-
version:
|
130
|
+
version: '0'
|
131
|
+
- !ruby/object:Gem::Dependency
|
131
132
|
name: cane
|
132
133
|
requirement: !ruby/object:Gem::Requirement
|
133
134
|
requirements:
|
134
|
-
- -
|
135
|
+
- - ">="
|
135
136
|
- !ruby/object:Gem::Version
|
136
137
|
version: 2.6.0
|
137
138
|
type: :development
|
138
139
|
prerelease: false
|
139
|
-
- !ruby/object:Gem::Dependency
|
140
140
|
version_requirements: !ruby/object:Gem::Requirement
|
141
141
|
requirements:
|
142
|
-
- -
|
142
|
+
- - ">="
|
143
143
|
- !ruby/object:Gem::Version
|
144
|
-
version:
|
144
|
+
version: 2.6.0
|
145
|
+
- !ruby/object:Gem::Dependency
|
145
146
|
name: bundler-audit
|
146
147
|
requirement: !ruby/object:Gem::Requirement
|
147
148
|
requirements:
|
148
|
-
- -
|
149
|
+
- - ">="
|
149
150
|
- !ruby/object:Gem::Version
|
150
151
|
version: '0'
|
151
152
|
type: :development
|
152
153
|
prerelease: false
|
153
|
-
- !ruby/object:Gem::Dependency
|
154
154
|
version_requirements: !ruby/object:Gem::Requirement
|
155
155
|
requirements:
|
156
|
-
- -
|
156
|
+
- - ">="
|
157
157
|
- !ruby/object:Gem::Version
|
158
158
|
version: '0'
|
159
|
-
|
159
|
+
- !ruby/object:Gem::Dependency
|
160
|
+
name: pry-byebug
|
160
161
|
requirement: !ruby/object:Gem::Requirement
|
161
162
|
requirements:
|
162
|
-
- -
|
163
|
+
- - ">="
|
163
164
|
- !ruby/object:Gem::Version
|
164
165
|
version: '0'
|
165
166
|
type: :development
|
166
167
|
prerelease: false
|
168
|
+
version_requirements: !ruby/object:Gem::Requirement
|
169
|
+
requirements:
|
170
|
+
- - ">="
|
171
|
+
- !ruby/object:Gem::Version
|
172
|
+
version: '0'
|
167
173
|
description:
|
168
174
|
email:
|
169
175
|
- napolskih@gmail.com
|
@@ -171,12 +177,18 @@ executables: []
|
|
171
177
|
extensions: []
|
172
178
|
extra_rdoc_files: []
|
173
179
|
files:
|
174
|
-
- .
|
180
|
+
- ".drone.yml"
|
181
|
+
- ".gitignore"
|
182
|
+
- ".rspec"
|
175
183
|
- CHANGELOG.md
|
176
184
|
- Gemfile
|
177
185
|
- Makefile
|
178
186
|
- README.md
|
179
187
|
- Rakefile
|
188
|
+
- dip.yml
|
189
|
+
- docker-compose.development.yml
|
190
|
+
- docker-compose.drone.yml
|
191
|
+
- docker-compose.yml
|
180
192
|
- lib/redis_counters.rb
|
181
193
|
- lib/redis_counters/base_counter.rb
|
182
194
|
- lib/redis_counters/bucket.rb
|
@@ -215,12 +227,12 @@ require_paths:
|
|
215
227
|
- lib
|
216
228
|
required_ruby_version: !ruby/object:Gem::Requirement
|
217
229
|
requirements:
|
218
|
-
- -
|
230
|
+
- - ">="
|
219
231
|
- !ruby/object:Gem::Version
|
220
232
|
version: '0'
|
221
233
|
required_rubygems_version: !ruby/object:Gem::Requirement
|
222
234
|
requirements:
|
223
|
-
- -
|
235
|
+
- - ">="
|
224
236
|
- !ruby/object:Gem::Version
|
225
237
|
version: '0'
|
226
238
|
requirements: []
|