示例#1
0
    def test_that_should_stop_if_max_retry_exceeded(self, create_copy_job, _):
        # given
        retry_count = 5

        # when
        ResultCheck().check(
            ResultCheckRequest(task_name_suffix="task_name_suffix",
                               copy_job_type_id="backups",
                               job_reference=BigQueryJobReference(
                                   project_id="target_project_id",
                                   job_id="job_id",
                                   location='EU'),
                               retry_count=retry_count,
                               post_copy_action_request=None))

        retry_count += 1

        ResultCheck().check(
            ResultCheckRequest(task_name_suffix="task_name_suffix",
                               copy_job_type_id="backups",
                               job_reference=BigQueryJobReference(
                                   project_id="target_project_id",
                                   job_id="job_id",
                                   location='EU'),
                               retry_count=retry_count,
                               post_copy_action_request=None))

        # then
        create_copy_job.assert_called_once()
示例#2
0
    def test_that_create_and_write_disposition_are_passed_to_result_check(
            self, create_copy_job_result_check, _):
        # given
        create_disposition = "SOME_CREATE_DISPOSITION"
        write_disposition = "SOME_WRITE_DISPOSITION"

        # when
        CopyJobService().run_copy_job_request(
            CopyJobRequest(task_name_suffix='task_name_suffix',
                           copy_job_type_id='test-process',
                           source_big_query_table=self.example_source_bq_table,
                           target_big_query_table=self.example_target_bq_table,
                           create_disposition=create_disposition,
                           write_disposition=write_disposition,
                           retry_count=0,
                           post_copy_action_request=None))

        # then
        create_copy_job_result_check.assert_called_once_with(
            ResultCheckRequest(task_name_suffix='task_name_suffix',
                               copy_job_type_id='test-process',
                               job_reference=BigQueryJobReference(
                                   project_id='test_project',
                                   job_id='job123',
                                   location='EU'),
                               retry_count=0,
                               post_copy_action_request=None))
示例#3
0
    def test_that_should_re_trigger_copy_job_task_with_proper_create_and_write_dispositions_if_retry_error_occurs(
            self, create_copy_job, _):
        # given
        retry_count = 0
        post_copy_action_request = \
            PostCopyActionRequest(url="/my/url", data={"key1": "value1"})
        create_disposition = "CREATE_NEVER"
        write_disposition = "WRITE_TRUNCATE"

        # when
        ResultCheck().check(
            ResultCheckRequest(
                task_name_suffix="task_name_suffix",
                copy_job_type_id="backups",
                job_reference=BigQueryJobReference(
                    project_id="target_project_id",
                    job_id="job_id",
                    location='EU'),
                retry_count=retry_count,
                post_copy_action_request=post_copy_action_request))

        # then
        copy_job_result = CopyJobResult(
            JobResultExample.DONE_WITH_RETRY_ERRORS)

        copy_job_request = CopyJobRequest(
            task_name_suffix=None,
            copy_job_type_id="backups",
            source_big_query_table=copy_job_result.source_bq_table,
            target_big_query_table=copy_job_result.target_bq_table,
            create_disposition=create_disposition,
            write_disposition=write_disposition,
            retry_count=retry_count + 1,
            post_copy_action_request=post_copy_action_request)
        create_copy_job.assert_called_once_with(copy_job_request)
示例#4
0
    def test_bug_regression_job_already_exists_after_internal_error(
            self, _, insert_job, _create_random_job_id,
            create_copy_job_result_check, table_metadata):
        # given
        post_copy_action_request = \
            PostCopyActionRequest(url='/my/url', data={'key1': 'value1'})
        table_metadata._BigQueryTableMetadata__get_table_or_partition.return_value.get_location.return_value = 'EU'

        # when
        CopyJobService().run_copy_job_request(
            CopyJobRequest(task_name_suffix='task_name_suffix',
                           copy_job_type_id='test-process',
                           source_big_query_table=self.example_source_bq_table,
                           target_big_query_table=self.example_target_bq_table,
                           create_disposition="CREATE_IF_NEEDED",
                           write_disposition="WRITE_EMPTY",
                           retry_count=0,
                           post_copy_action_request=post_copy_action_request))

        # then
        self.assertEqual(insert_job.call_count, 2)
        create_copy_job_result_check.assert_called_once_with(
            ResultCheckRequest(
                task_name_suffix='task_name_suffix',
                copy_job_type_id='test-process',
                job_reference=BigQueryJobReference(
                    project_id='target_project_id_1',
                    job_id='random_job_123',
                    location='EU'),
                retry_count=0,
                post_copy_action_request=post_copy_action_request))
示例#5
0
    def test_that_post_copy_action_request_is_passed(
            self, create_copy_job_result_check, _):
        # given
        post_copy_action_request = \
            PostCopyActionRequest(url='/my/url', data={'key1': 'value1'})

        # when
        CopyJobService().run_copy_job_request(
            CopyJobRequest(task_name_suffix='task_name_suffix',
                           copy_job_type_id='test-process',
                           source_big_query_table=self.example_source_bq_table,
                           target_big_query_table=self.example_target_bq_table,
                           create_disposition="CREATE_IF_NEEDED",
                           write_disposition="WRITE_EMPTY",
                           retry_count=0,
                           post_copy_action_request=post_copy_action_request))

        # then
        create_copy_job_result_check.assert_called_once_with(
            ResultCheckRequest(
                task_name_suffix='task_name_suffix',
                copy_job_type_id='test-process',
                job_reference=BigQueryJobReference(project_id='test_project',
                                                   job_id='job123',
                                                   location='EU'),
                retry_count=0,
                post_copy_action_request=post_copy_action_request))
示例#6
0
    def test_copy_job_result_check_creation(self):
        # given
        result_check_request = ResultCheckRequest(
            task_name_suffix='task-name-suffix',
            copy_job_type_id='backups',
            job_reference=BigQueryJobReference(project_id="project_abc",
                                               job_id="job123",
                                               location='EU'),
            retry_count=2,
            post_copy_action_request=PostCopyActionRequest(
                url="/my/url",
                data={"key1": "value1"})
        )
        TaskCreator.create_copy_job_result_check(result_check_request)

        # then
        expected_queue_name = 'backups-result-check'
        executed_tasks = self.taskqueue_stub.get_filtered_tasks(
            queue_names=expected_queue_name
        )

        self.assertEqual(len(executed_tasks), 1,
                         "Should create one task in queue")
        executed_task = executed_tasks[0]
        self.assertEqual(json.dumps(result_check_request, cls=RequestEncoder),
                         executed_task.extract_params()['resultCheckRequest'])
        self.assertEqual('POST', executed_task.method)
        self.assertEqual(executed_task.url,
                         '/tasks/copy_job_async/result_check')
示例#7
0
 def create_post_copy_action(self, copy_job_request):
     TaskCreator.create_copy_job_result_check(
         ResultCheckRequest(
             task_name_suffix=copy_job_request.task_name_suffix,
             copy_job_type_id=copy_job_request.copy_job_type_id,
             job_reference=self,
             retry_count=copy_job_request.retry_count,
             post_copy_action_request=copy_job_request.
             post_copy_action_request))
 def create_example_result_check_request(project_id, job_id, location,
                                         retry_count,
                                         post_copy_action_request):
     return ResultCheckRequest(
         task_name_suffix=None,
         copy_job_type_id=None,
         job_reference=BigQueryJobReference(project_id=project_id,
                                            job_id=job_id,
                                            location=location),
         retry_count=retry_count,
         post_copy_action_request=post_copy_action_request)
示例#9
0
 def test_copy_job_result_check_task_should_not_be_created_when_retry_smaller_than_0(
         self):
     with self.assertRaises(AssertionError):
         TaskCreator.create_copy_job_result_check(
             ResultCheckRequest(
                 task_name_suffix=None,
                 copy_job_type_id='backups',
                 job_reference=BigQueryJobReference(project_id="project_abc",
                                                    job_id="job123",
                                                    location='EU'),
                 retry_count=-1
             )
         )
示例#10
0
 def create_example_result_check_request(self):
     retry_count = 0
     post_copy_action_request = \
         PostCopyActionRequest(url="/my/url", data={"key1": "value1"})
     # when
     result_check_request = ResultCheckRequest(
         task_name_suffix="task_name_suffix",
         copy_job_type_id="backups",
         job_reference=BigQueryJobReference(project_id="target_project_id",
                                            job_id="job_id",
                                            location='EU'),
         retry_count=retry_count,
         post_copy_action_request=post_copy_action_request)
     return result_check_request
示例#11
0
 def test_create_copy_job_result_check_throws_error_on_unknown_queue(self):
     # when
     with self.assertRaises(UnknownQueueError) as error:
         TaskCreator.create_copy_job_result_check(ResultCheckRequest(
             task_name_suffix=None,
             copy_job_type_id="unknown-copying",
             job_reference=BigQueryJobReference(project_id="project_abc",
                                                job_id="job123",
                                                location='EU'),
             retry_count=0,
             post_copy_action_request=PostCopyActionRequest(
                 '/my/post/copy/url', {'mypayload': 'mypayload_value'}))
         )
     self.assertEqual(error.exception.message,
                      "There is no queue 'unknown-copying-result-check'. "
                      "Please add it to your queue.yaml definition.")
示例#12
0
    def test_that_after_successful_job_no_post_action_is_created(
            self, create_post_copy_action, _):
        # given
        post_copy_action_request = None

        # when
        ResultCheck().check(
            ResultCheckRequest(
                task_name_suffix='task_name_suffix',
                copy_job_type_id="backups",
                job_reference=BigQueryJobReference(
                    project_id="target_project_id",
                    job_id="job_id",
                    location='EU'),
                retry_count=0,
                post_copy_action_request=post_copy_action_request))

        # then
        create_post_copy_action.assert_not_called()
 def __deserialize_result_check_request(request):
     result_check_request_json = json.loads(
         request.get("resultCheckRequest"))
     return ResultCheckRequest.from_json(result_check_request_json)
示例#14
0
    def test_that_copy_table_will_try_to_wait_if_deadline_exceeded(
            self, create_copy_job_result_check, insert_job, get_job):
        # given
        http_error_content = "{\"error\": " \
                             "  {\"errors\": [" \
                             "    {\"reason\": \"Deadline exceeded\"," \
                             "     \"message\": \"Deadline exceeded\"," \
                             "     \"location\": \"US\"" \
                             "  }]," \
                             "  \"code\": 500," \
                             "  \"message\": \"Deadline exceeded\"}}"
        successful_job_json = {
            'status': {
                'state': 'DONE'
            },
            'jobReference': {
                'projectId': self.example_target_bq_table.get_project_id(),
                'location': 'EU',
                'jobId': 'job123',
            },
            'configuration': {
                'copy': {
                    'sourceTable': {
                        'projectId':
                        self.example_source_bq_table.get_project_id(),
                        'tableId': self.example_source_bq_table.get_table_id(),
                        'datasetId':
                        self.example_source_bq_table.get_dataset_id()
                    },
                    'destinationTable': {
                        'projectId':
                        self.example_target_bq_table.get_project_id(),
                        'tableId': self.example_target_bq_table.get_table_id(),
                        'datasetId':
                        self.example_target_bq_table.get_dataset_id()
                    }
                }
            }
        }

        insert_job.side_effect = HttpError(Mock(status=500),
                                           http_error_content)
        get_job.return_value = successful_job_json

        request = CopyJobRequest(
            task_name_suffix='task_name_suffix',
            copy_job_type_id='test-process',
            source_big_query_table=self.example_source_bq_table,
            target_big_query_table=self.example_target_bq_table,
            create_disposition="CREATE_IF_NEEDED",
            write_disposition="WRITE_EMPTY",
            retry_count=0,
            post_copy_action_request=None)

        # when
        CopyJobService().run_copy_job_request(request)

        # then
        create_copy_job_result_check.assert_called_once_with(
            ResultCheckRequest(
                task_name_suffix='task_name_suffix',
                copy_job_type_id='test-process',
                job_reference=BigQueryJobReference(
                    project_id=self.example_target_bq_table.get_project_id(),
                    job_id='job123',
                    location='EU'),
                retry_count=0,
                post_copy_action_request=None))