perfectqueue 0.8.44.1 → 0.8.45

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.
@@ -0,0 +1,70 @@
1
+ require 'spec_helper'
2
+
3
+ describe PerfectQueue::Task do
4
+ describe '.new' do
5
+ it 'returns a Task' do
6
+ task = Task.new(double, double)
7
+ expect(task).to be_an_instance_of(Task)
8
+ end
9
+ end
10
+
11
+ describe '#config' do
12
+ it 'returns the client' do
13
+ config = double('config')
14
+ client = double('client', config: config)
15
+ key = double('key')
16
+ task = Task.new(client, key)
17
+ expect(task).to be_an_instance_of(Task)
18
+ expect(task.client).to eq(client)
19
+ expect(task.config).to eq(config)
20
+ end
21
+ end
22
+
23
+ describe '#preempt' do
24
+ it 'returns inspected string' do
25
+ client = double('client')
26
+ key = double('key')
27
+ task = Task.new(client, key)
28
+ options = double('options')
29
+ ret = double('ret')
30
+ expect(client).to receive(:preempt).with(key, options).exactly(:once).and_return(ret)
31
+ expect(task.preempt(options)).to eq(ret)
32
+ end
33
+ end
34
+
35
+ describe '#inspect' do
36
+ it 'returns inspected string' do
37
+ key = double('key')
38
+ task = Task.new(double('client'), key)
39
+ expect(task.inspect).to eq("#<PerfectQueue::Task @key=#{key.inspect}>")
40
+ end
41
+ end
42
+
43
+ describe '#update_data!' do
44
+ context 'PLT-4238' do
45
+ let (:config){ {type: 'rdb_compat', url: 'mysql://root:@localhost/perfectqueue_test', table: 'test_queues', type: 'rdb_compat'} }
46
+ let (:client){ Client.new(config) }
47
+ before do
48
+ client.backend.db.tap{|s| s.tables.each{|t| s.drop_table(t) } }
49
+ client.init_database
50
+ client.submit('key', 'test1', {'foo' => 1}, {compression: 'gzip'})
51
+ end
52
+ it 'keeps the data compressed' do
53
+ tasks = client.acquire
54
+ expect(tasks.size).to eq 1
55
+ task = tasks.first
56
+ expect(task.compression).to eq 'gzip'
57
+ task.update_data!('hoge' => 2)
58
+ task.release!
59
+
60
+ tasks = client.acquire
61
+ task = tasks.first
62
+ expect(tasks.size).to eq 1
63
+ expect(task.compression).to eq 'gzip'
64
+ data = task.data
65
+ expect(data['foo']).to eq 1
66
+ expect(data['hoge']).to eq 2
67
+ end
68
+ end
69
+ end
70
+ end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: perfectqueue
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.8.44.1
4
+ version: 0.8.45
5
5
  platform: ruby
6
6
  authors:
7
7
  - Sadayuki Furuhashi
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2016-06-14 00:00:00.000000000 Z
11
+ date: 2015-12-02 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: sequel
@@ -44,14 +44,14 @@ dependencies:
44
44
  requirements:
45
45
  - - "~>"
46
46
  - !ruby/object:Gem::Version
47
- version: 2.10.0
47
+ version: 3.3.0
48
48
  type: :development
49
49
  prerelease: false
50
50
  version_requirements: !ruby/object:Gem::Requirement
51
51
  requirements:
52
52
  - - "~>"
53
53
  - !ruby/object:Gem::Version
54
- version: 2.10.0
54
+ version: 3.3.0
55
55
  - !ruby/object:Gem::Dependency
56
56
  name: simplecov
57
57
  requirement: !ruby/object:Gem::Requirement
@@ -66,20 +66,6 @@ dependencies:
66
66
  - - "~>"
67
67
  - !ruby/object:Gem::Version
68
68
  version: 0.10.0
69
- - !ruby/object:Gem::Dependency
70
- name: sqlite3
71
- requirement: !ruby/object:Gem::Requirement
72
- requirements:
73
- - - "~>"
74
- - !ruby/object:Gem::Version
75
- version: 1.3.3
76
- type: :development
77
- prerelease: false
78
- version_requirements: !ruby/object:Gem::Requirement
79
- requirements:
80
- - - "~>"
81
- - !ruby/object:Gem::Version
82
- version: 1.3.3
83
69
  - !ruby/object:Gem::Dependency
84
70
  name: mysql2
85
71
  requirement: !ruby/object:Gem::Requirement
@@ -143,11 +129,29 @@ files:
143
129
  - lib/perfectqueue/version.rb
144
130
  - lib/perfectqueue/worker.rb
145
131
  - perfectqueue.gemspec
132
+ - spec/application/base_spec.rb
133
+ - spec/application/decider_spec.rb
134
+ - spec/application/dispatch_spec.rb
135
+ - spec/application/router_spec.rb
136
+ - spec/backend_spec.rb
137
+ - spec/blocking_flag_spec.rb
138
+ - spec/client_spec.rb
139
+ - spec/daemons_logger_spec.rb
140
+ - spec/engine_spec.rb
141
+ - spec/multiprocess/child_process_monitor_spec.rb
142
+ - spec/multiprocess/child_process_spec.rb
143
+ - spec/multiprocess/fork_processor_spec.rb
144
+ - spec/multiprocess/thread_processor_spec.rb
146
145
  - spec/queue_spec.rb
147
146
  - spec/rdb_compat_backend_spec.rb
147
+ - spec/runner_spec.rb
148
+ - spec/signal_thread_spec.rb
148
149
  - spec/spec_helper.rb
149
150
  - spec/stress.rb
150
151
  - spec/supervisor_spec.rb
152
+ - spec/task_metadata_spec.rb
153
+ - spec/task_monitor_spec.rb
154
+ - spec/task_spec.rb
151
155
  homepage: https://github.com/treasure-data/perfectqueue
152
156
  licenses:
153
157
  - Apache 2.0
@@ -173,9 +177,26 @@ signing_key:
173
177
  specification_version: 4
174
178
  summary: Highly available distributed cron built on RDBMS
175
179
  test_files:
180
+ - spec/application/base_spec.rb
181
+ - spec/application/decider_spec.rb
182
+ - spec/application/dispatch_spec.rb
183
+ - spec/application/router_spec.rb
184
+ - spec/backend_spec.rb
185
+ - spec/blocking_flag_spec.rb
186
+ - spec/client_spec.rb
187
+ - spec/daemons_logger_spec.rb
188
+ - spec/engine_spec.rb
189
+ - spec/multiprocess/child_process_monitor_spec.rb
190
+ - spec/multiprocess/child_process_spec.rb
191
+ - spec/multiprocess/fork_processor_spec.rb
192
+ - spec/multiprocess/thread_processor_spec.rb
176
193
  - spec/queue_spec.rb
177
194
  - spec/rdb_compat_backend_spec.rb
195
+ - spec/runner_spec.rb
196
+ - spec/signal_thread_spec.rb
178
197
  - spec/spec_helper.rb
179
198
  - spec/stress.rb
180
199
  - spec/supervisor_spec.rb
181
- has_rdoc: false
200
+ - spec/task_metadata_spec.rb
201
+ - spec/task_monitor_spec.rb
202
+ - spec/task_spec.rb