| 1 | # -*-perl-*- |
|---|
| 2 | |
|---|
| 3 | use strict; |
|---|
| 4 | use warnings; |
|---|
| 5 | |
|---|
| 6 | require 't/lib/db-common.pl'; |
|---|
| 7 | |
|---|
| 8 | use TheSchwartz; |
|---|
| 9 | use Test::More tests => 28; |
|---|
| 10 | |
|---|
| 11 | run_tests(14, sub { |
|---|
| 12 | my $client = test_client(dbs => ['ts1']); |
|---|
| 13 | |
|---|
| 14 | my @keys = qw(foo bar baz); |
|---|
| 15 | my $n = 0; |
|---|
| 16 | for (1..10) { |
|---|
| 17 | my $key = $keys[$n++ % 3]; |
|---|
| 18 | my $job = TheSchwartz::Job->new( |
|---|
| 19 | funcname => 'Worker::CoalesceTest', |
|---|
| 20 | arg => { key => $key, num => $_ }, |
|---|
| 21 | coalesce => $key |
|---|
| 22 | ); |
|---|
| 23 | my $h = $client->insert($job); |
|---|
| 24 | ok($h, "inserted $h ($_ = $key)"); |
|---|
| 25 | } |
|---|
| 26 | |
|---|
| 27 | $client->reset_abilities; |
|---|
| 28 | $client->can_do("Worker::CoalesceTest"); |
|---|
| 29 | |
|---|
| 30 | Worker::CoalesceTest->set_client($client); |
|---|
| 31 | |
|---|
| 32 | for (1..3) { |
|---|
| 33 | my $rv = eval { $client->work_once; }; |
|---|
| 34 | ok($rv, "did stuff"); |
|---|
| 35 | } |
|---|
| 36 | my $rv = eval { $client->work_once; }; |
|---|
| 37 | ok(!$rv, "nothing to do now"); |
|---|
| 38 | |
|---|
| 39 | teardown_dbs('ts1'); |
|---|
| 40 | }); |
|---|
| 41 | |
|---|
| 42 | ############################################################################ |
|---|
| 43 | package Worker::CoalesceTest; |
|---|
| 44 | use base 'TheSchwartz::Worker'; |
|---|
| 45 | |
|---|
| 46 | my $client; |
|---|
| 47 | sub set_client { $client = $_[1]; } |
|---|
| 48 | |
|---|
| 49 | sub work { |
|---|
| 50 | my ($class, $job) = @_; |
|---|
| 51 | my $args = $job->arg; |
|---|
| 52 | |
|---|
| 53 | my $key = $args->{key}; |
|---|
| 54 | $job->completed; |
|---|
| 55 | |
|---|
| 56 | if ($key eq "foo") { |
|---|
| 57 | while (my $job = $client->find_job_with_coalescing_prefix("Worker::CoalesceTest", "f")) { |
|---|
| 58 | $job->completed; |
|---|
| 59 | } |
|---|
| 60 | } else { |
|---|
| 61 | while (my $job = $client->find_job_with_coalescing_value("Worker::CoalesceTest", $key)) { |
|---|
| 62 | $job->completed; |
|---|
| 63 | } |
|---|
| 64 | } |
|---|
| 65 | } |
|---|
| 66 | |
|---|
| 67 | sub keep_exit_status_for { 20 } # keep exit status for 20 seconds after on_complete |
|---|
| 68 | |
|---|
| 69 | sub grab_for { 10 } |
|---|
| 70 | |
|---|
| 71 | sub max_retries { 1 } |
|---|
| 72 | |
|---|
| 73 | sub retry_delay { my $class = shift; my $fails = shift; return 2 ** $fails; } |
|---|
| 74 | |
|---|