1 /*  vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
2  *
3  *  Gearmand client and server library.
4  *
5  *  Copyright (C) 2011 Data Differential, http://datadifferential.com/
6  *  All rights reserved.
7  *
8  *  Redistribution and use in source and binary forms, with or without
9  *  modification, are permitted provided that the following conditions are
10  *  met:
11  *
12  *      * Redistributions of source code must retain the above copyright
13  *  notice, this list of conditions and the following disclaimer.
14  *
15  *      * Redistributions in binary form must reproduce the above
16  *  copyright notice, this list of conditions and the following disclaimer
17  *  in the documentation and/or other materials provided with the
18  *  distribution.
19  *
20  *      * The names of its contributors may not be used to endorse or
21  *  promote products derived from this software without specific prior
22  *  written permission.
23  *
24  *  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
25  *  "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
26  *  LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
27  *  A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
28  *  OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
29  *  SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
30  *  LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
31  *  DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
32  *  THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
33  *  (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
34  *  OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
35  *
36  */
37 
38 #include <gear_config.h>
39 #include <libtest/test.hpp>
40 
41 using namespace libtest;
42 
43 #include <libgearman-1.0/gearman.h>
44 
45 #include "tests/workers/v2/split.h"
46 
47 #include <cassert>
48 #include <cstring>
49 
50 
split_worker(gearman_job_st * job,void *)51 gearman_return_t split_worker(gearman_job_st *job, void* /* context */)
52 {
53   const char *workload= static_cast<const char *>(gearman_job_workload(job));
54   size_t workload_size= gearman_job_workload_size(job);
55 
56   assert(job->assigned.command == GEARMAN_COMMAND_JOB_ASSIGN_ALL);
57 
58   const char *chunk_begin= workload;
59   for (size_t x= 0; x < workload_size; x++)
60   {
61     if (int(workload[x]) == 0 or int(workload[x]) == int(' '))
62     {
63       if ((workload +x -chunk_begin) == 11 and not memcmp(chunk_begin, test_literal_param("mapper_fail")))
64       {
65         return GEARMAN_FAIL;
66       }
67 
68       // NULL Chunk
69       gearman_return_t rc= gearman_job_send_data(job, chunk_begin, workload +x -chunk_begin);
70       if (gearman_failed(rc))
71       {
72         return GEARMAN_FAIL;
73       }
74 
75       chunk_begin= workload +x +1;
76     }
77   }
78 
79   if (chunk_begin < workload +workload_size)
80   {
81     if ((size_t(workload +workload_size) -size_t(chunk_begin) ) == 11 and not memcmp(chunk_begin, test_literal_param("mapper_fail")))
82     {
83       return GEARMAN_FAIL;
84     }
85 
86     gearman_return_t rc= gearman_job_send_data(job, chunk_begin, size_t(workload +workload_size) -size_t(chunk_begin));
87     if (gearman_failed(rc))
88     {
89       return GEARMAN_FAIL;
90     }
91   }
92 
93   return GEARMAN_SUCCESS;
94 }
95 
96