class DownloadFlowTest in TMGMT Translator Smartling 8.4
Same name and namespace in other branches
- 8.3 tests/src/Kernel/DownloadFlowTest.php \Drupal\Tests\tmgmt_smartling\Kernel\DownloadFlowTest
Tests file download flow.
@group tmgmt_smartling
Hierarchy
- class \Drupal\KernelTests\KernelTestBase extends \PHPUnit\Framework\TestCase implements ServiceProviderInterface uses AssertContentTrait, AssertLegacyTrait, AssertHelperTrait, ConfigTestTrait, PhpunitCompatibilityTrait, RandomGeneratorTrait, TestRequirementsTrait- class \Drupal\Tests\tmgmt\Kernel\TMGMTKernelTestBase- class \Drupal\Tests\tmgmt_smartling\Kernel\SmartlingTestBase- class \Drupal\Tests\tmgmt_smartling\Kernel\DownloadFlowTest
 
 
- class \Drupal\Tests\tmgmt_smartling\Kernel\SmartlingTestBase
 
- class \Drupal\Tests\tmgmt\Kernel\TMGMTKernelTestBase
Expanded class hierarchy of DownloadFlowTest
File
- tests/src/ Kernel/ DownloadFlowTest.php, line 16 
Namespace
Drupal\Tests\tmgmt_smartling\KernelView source
class DownloadFlowTest extends SmartlingTestBase {
  /**
   * Download success full flow.
   */
  public function testDownloadSuccessFullFlow() {
    $translate_job = $this
      ->createJobWithItems([
      'batch_uid' => 'uid',
      'batch_execute_on_job' => 1,
    ]);
    $this->translationRequestManagerMock
      ->expects($this
      ->never())
      ->method('commitError');
    $this->translationRequestManagerMock
      ->expects($this
      ->once())
      ->method('getTranslationRequest')
      ->with($translate_job)
      ->willReturn([
      'translationRequestUid' => 'test',
      'fileUri' => 'test_file_uri.xml',
    ]);
    $this->apiWrapperMock
      ->expects($this
      ->once())
      ->method('getApi')
      ->with('file')
      ->willReturn($this->fileApiMock);
    $this->apiWrapperMock
      ->expects($this
      ->once())
      ->method('createAuditLogRecord')
      ->with($translate_job, NULL, \Drupal::currentUser(), CreateRecordParameters::ACTION_TYPE_DOWNLOAD);
    $this->fileApiMock
      ->expects($this
      ->once())
      ->method('downloadFile')
      ->with('test_file_uri.xml', 'de', $this
      ->callback(function ($subject) {
      $params = $subject
        ->exportToArray();
      return $params['retrievalType'] == 'published';
    }))
      ->willReturn('xml');
    $this->pluginMock
      ->expects($this
      ->once())
      ->method('validateImport')
      ->with('public://tmgmt_smartling_translations/test_file_uri.xml', $translate_job)
      ->willReturn(TRUE);
    $this->pluginMock
      ->expects($this
      ->once())
      ->method('import')
      ->with('public://tmgmt_smartling_translations/test_file_uri.xml', $translate_job)
      ->willReturn([]);
    $this->translationRequestManagerMock
      ->expects($this
      ->once())
      ->method('commitSuccessfulDownload')
      ->with($translate_job)
      ->willReturn(FALSE);
    $this->apiWrapperMock
      ->expects($this
      ->at(2))
      ->method('createFirebaseRecord')
      ->with('tmgmt_smartling', 'notifications', 10, [
      "message" => 'Translation for "public://tmgmt_smartling_translations/test_file_uri.xml" (job id = 1) was successfully downloaded and imported.',
      "type" => "status",
    ]);
    $this->apiWrapperMock
      ->expects($this
      ->at(3))
      ->method('createFirebaseRecord')
      ->with('tmgmt_smartling', 'notifications', 10, [
      "message" => 'Can\'t update update state and exported date for translation request. See logs for more info.',
      "type" => "warning",
    ]);
    tmgmt_smartling_download_file($translate_job);
  }
  /**
   * Download fail flow: get translation request failed.
   */
  public function testDownloadFailFlowGetTranslationRequestFailed() {
    $translate_job = $this
      ->createJobWithItems([
      'batch_uid' => 'uid',
      'batch_execute_on_job' => 1,
    ]);
    $this->translationRequestManagerMock
      ->expects($this
      ->never())
      ->method('commitError');
    $this->translationRequestManagerMock
      ->expects($this
      ->once())
      ->method('getTranslationRequest')
      ->with($translate_job)
      ->willReturn(FALSE);
    $this->apiWrapperMock
      ->expects($this
      ->never())
      ->method('getApi');
    $this->fileApiMock
      ->expects($this
      ->never())
      ->method('downloadFile');
    $this->translationRequestManagerMock
      ->expects($this
      ->never())
      ->method('commitSuccessfulDownload');
    $this->pluginMock
      ->expects($this
      ->never())
      ->method('validateImport');
    $this->pluginMock
      ->expects($this
      ->never())
      ->method('import');
    $this->apiWrapperMock
      ->expects($this
      ->once())
      ->method('createFirebaseRecord')
      ->with('tmgmt_smartling', 'notifications', 10, [
      "message" => 'File JobID1_en_de.xml (job id = 1) wasn\'t downloaded: can\'t find related translation request. See logs for more info.',
      "type" => "error",
    ]);
    tmgmt_smartling_download_file($translate_job);
  }
  /**
   * Download success partial flow: import skipped.
   */
  public function testDownloadSuccessPartialFlowImportSkipped() {
    $translate_job = $this
      ->createJobWithItems([
      'batch_uid' => 'uid',
      'batch_execute_on_job' => 1,
    ]);
    $translate_job
      ->set('job_file_content_hash', '0f635d0e0f3874fff8b581c132e6c7a7');
    // Remove job items in order to not to force import. We need to avoid
    // Drupal::entityTypeManager mocking. See tmgmt_smartling_download_file,
    // line 94.
    foreach ($translate_job
      ->getItems() as $item) {
      $item
        ->delete();
    }
    $translate_job
      ->save();
    $this->translationRequestManagerMock
      ->expects($this
      ->never())
      ->method('commitError');
    $this->translationRequestManagerMock
      ->expects($this
      ->once())
      ->method('getTranslationRequest')
      ->willReturn([
      'translationRequestUid' => 'test',
      'fileUri' => 'test_file_uri.xml',
    ]);
    $this->apiWrapperMock
      ->expects($this
      ->once())
      ->method('getApi')
      ->with('file')
      ->willReturn($this->fileApiMock);
    $this->apiWrapperMock
      ->expects($this
      ->once())
      ->method('createAuditLogRecord')
      ->with($translate_job, NULL, \Drupal::currentUser(), CreateRecordParameters::ACTION_TYPE_DOWNLOAD);
    $this->fileApiMock
      ->expects($this
      ->once())
      ->method('downloadFile')
      ->with('test_file_uri.xml', 'de', $this
      ->callback(function ($subject) {
      $params = $subject
        ->exportToArray();
      return $params['retrievalType'] == 'published';
    }))
      ->willReturn('xml');
    $this->translationRequestManagerMock
      ->expects($this
      ->once())
      ->method('commitSuccessfulDownload')
      ->with($translate_job)
      ->willReturn(TRUE);
    $this->pluginMock
      ->expects($this
      ->once())
      ->method('validateImport')
      ->with('public://tmgmt_smartling_translations/test_file_uri.xml', $translate_job)
      ->willReturn(TRUE);
    $this->pluginMock
      ->expects($this
      ->never())
      ->method('import');
    $this->apiWrapperMock
      ->expects($this
      ->once())
      ->method('createFirebaseRecord')
      ->with('tmgmt_smartling', 'notifications', 10, [
      "message" => 'Translation for "public://tmgmt_smartling_translations/test_file_uri.xml" (job id = 1) was successfully downloaded but import was skipped: downloaded and existing translations are equal.',
      "type" => "warning",
    ]);
    tmgmt_smartling_download_file($translate_job);
  }
  /**
   * Download fail flow.
   */
  public function testDownloadFailFlow() {
    $exception = new \Exception("Test");
    $translation_request = [
      'translationRequestUid' => 'test',
      'fileUri' => 'test_file_uri.xml',
    ];
    $translate_job = $this
      ->createJobWithItems([
      'batch_uid' => 'uid',
      'batch_execute_on_job' => 1,
    ]);
    $this->translationRequestManagerMock
      ->expects($this
      ->once())
      ->method('getTranslationRequest')
      ->with($translate_job)
      ->willReturn($translation_request);
    $this->apiWrapperMock
      ->expects($this
      ->once())
      ->method('getApi')
      ->with('file')
      ->willReturn($this->fileApiMock);
    $this->apiWrapperMock
      ->expects($this
      ->once())
      ->method('createAuditLogRecord')
      ->with($translate_job, NULL, \Drupal::currentUser(), CreateRecordParameters::ACTION_TYPE_DOWNLOAD);
    $this->fileApiMock
      ->expects($this
      ->once())
      ->method('downloadFile')
      ->with('test_file_uri.xml', 'de', $this
      ->callback(function ($subject) {
      $params = $subject
        ->exportToArray();
      return $params['retrievalType'] == 'published';
    }))
      ->will($this
      ->throwException($exception));
    $this->translationRequestManagerMock
      ->expects($this
      ->once())
      ->method('commitError')
      ->with($translate_job, $translation_request, $exception);
    $this->translationRequestManagerMock
      ->expects($this
      ->never())
      ->method('commitSuccessfulDownload');
    $this->pluginMock
      ->expects($this
      ->never())
      ->method('validateImport');
    $this->pluginMock
      ->expects($this
      ->never())
      ->method('import');
    $this->apiWrapperMock
      ->expects($this
      ->once())
      ->method('createFirebaseRecord')
      ->with('tmgmt_smartling', 'notifications', 10, [
      "message" => 'File test_file_uri.xml (job id = 1) wasn\'t downloaded. Please see logs for more info.',
      "type" => "error",
    ]);
    tmgmt_smartling_download_file($translate_job);
  }
  /**
   * Download fail flow: validation failed.
   */
  public function testDownloadFailFlowValidationFailed() {
    $translate_job = $this
      ->createJobWithItems([
      'batch_uid' => 'uid',
      'batch_execute_on_job' => 1,
    ]);
    $this->translationRequestManagerMock
      ->expects($this
      ->never())
      ->method('commitError');
    $this->translationRequestManagerMock
      ->expects($this
      ->once())
      ->method('getTranslationRequest')
      ->with($translate_job)
      ->willReturn([
      'translationRequestUid' => 'test',
      'fileUri' => 'test_file_uri.xml',
    ]);
    $this->apiWrapperMock
      ->expects($this
      ->once())
      ->method('getApi')
      ->with('file')
      ->willReturn($this->fileApiMock);
    $this->apiWrapperMock
      ->expects($this
      ->once())
      ->method('createAuditLogRecord')
      ->with($translate_job, NULL, \Drupal::currentUser(), CreateRecordParameters::ACTION_TYPE_DOWNLOAD);
    $this->fileApiMock
      ->expects($this
      ->once())
      ->method('downloadFile')
      ->with('test_file_uri.xml', 'de', $this
      ->callback(function ($subject) {
      $params = $subject
        ->exportToArray();
      return $params['retrievalType'] == 'published';
    }))
      ->willReturn('xml');
    $this->pluginMock
      ->expects($this
      ->once())
      ->method('validateImport')
      ->with('public://tmgmt_smartling_translations/test_file_uri.xml', $translate_job)
      ->willReturn(FALSE);
    $this->pluginMock
      ->expects($this
      ->never())
      ->method('import');
    $this->translationRequestManagerMock
      ->expects($this
      ->never())
      ->method('commitSuccessfulDownload');
    $this->apiWrapperMock
      ->expects($this
      ->once())
      ->method('createFirebaseRecord')
      ->with('tmgmt_smartling', 'notifications', 10, [
      "message" => 'Translation for "public://tmgmt_smartling_translations/test_file_uri.xml" (job id = 1) was successfully downloaded but validation failed. See logs for more info.',
      "type" => "error",
    ]);
    tmgmt_smartling_download_file($translate_job);
  }
  /**
   * Download fail flow: import failed.
   */
  public function testDownloadFailFlowImportFailed() {
    $exception = new \Exception("Test");
    $translation_request = [
      'translationRequestUid' => 'test',
      'fileUri' => 'test_file_uri.xml',
    ];
    $translate_job = $this
      ->createJobWithItems([
      'batch_uid' => 'uid',
      'batch_execute_on_job' => 1,
    ]);
    $this->translationRequestManagerMock
      ->expects($this
      ->once())
      ->method('getTranslationRequest')
      ->with($translate_job)
      ->willReturn($translation_request);
    $this->apiWrapperMock
      ->expects($this
      ->once())
      ->method('getApi')
      ->with('file')
      ->willReturn($this->fileApiMock);
    $this->apiWrapperMock
      ->expects($this
      ->once())
      ->method('createAuditLogRecord')
      ->with($translate_job, NULL, \Drupal::currentUser(), CreateRecordParameters::ACTION_TYPE_DOWNLOAD);
    $this->fileApiMock
      ->expects($this
      ->once())
      ->method('downloadFile')
      ->with('test_file_uri.xml', 'de', $this
      ->callback(function ($subject) {
      $params = $subject
        ->exportToArray();
      return $params['retrievalType'] == 'published';
    }))
      ->willReturn('xml');
    $this->pluginMock
      ->expects($this
      ->once())
      ->method('validateImport')
      ->with('public://tmgmt_smartling_translations/test_file_uri.xml', $translate_job)
      ->willReturn(TRUE);
    $this->pluginMock
      ->expects($this
      ->once())
      ->method('import')
      ->with('public://tmgmt_smartling_translations/test_file_uri.xml', $translate_job)
      ->will($this
      ->throwException($exception));
    $this->translationRequestManagerMock
      ->expects($this
      ->never())
      ->method('commitSuccessfulDownload');
    $this->translationRequestManagerMock
      ->expects($this
      ->once())
      ->method('commitError')
      ->with($translate_job, $translation_request, $exception);
    $this->apiWrapperMock
      ->expects($this
      ->once())
      ->method('createFirebaseRecord')
      ->with('tmgmt_smartling', 'notifications', 10, [
      "message" => 'Translation for "public://tmgmt_smartling_translations/test_file_uri.xml" (job id = 1) was successfully downloaded but import failed. See logs for more info.',
      "type" => "error",
    ]);
    tmgmt_smartling_download_file($translate_job);
  }
  /**
   * Download success full flow: download by TMGMT Job (all TMGMT Job Items).
   */
  public function testDownloadByTmgmtJob() {
    $real_job = $this
      ->createJobWithItems([
      'batch_uid' => 'uid',
      'batch_execute_on_job' => 1,
    ]);
    $field_item_list = $this
      ->getMockBuilder(FieldItemList::class)
      ->disableOriginalConstructor()
      ->setMethods([
      'getValue',
    ])
      ->getMock();
    $field_item_list
      ->expects($this
      ->any())
      ->method('getValue')
      ->willReturn([
      0 => [
        'value' => NULL,
      ],
    ]);
    $job_item_mock_1 = $this
      ->getMockBuilder(JobItem::class)
      ->disableOriginalConstructor()
      ->setMethods([
      'save',
      'id',
      'setState',
      'addTranslatedData',
      'getItemId',
      'getItemType',
    ])
      ->getMock();
    $job_item_mock_1
      ->expects($this
      ->any())
      ->method('id')
      ->willReturn(1);
    $job_item_mock_1
      ->expects($this
      ->any())
      ->method('getItemId')
      ->willReturn(1);
    $job_item_mock_1
      ->expects($this
      ->any())
      ->method('getItemType')
      ->willReturn('node');
    $job_item_mock_1
      ->expects($this
      ->once())
      ->method('setState')
      ->with(JobItemInterface::STATE_ACTIVE);
    $job_item_mock_1
      ->expects($this
      ->once())
      ->method('addTranslatedData');
    $job_item_mock_2 = $this
      ->getMockBuilder(JobItem::class)
      ->disableOriginalConstructor()
      ->setMethods([
      'id',
      'setState',
      'addTranslatedData',
      'getItemId',
      'getItemType',
    ])
      ->getMock();
    $job_item_mock_2
      ->expects($this
      ->any())
      ->method('id')
      ->willReturn(2);
    $job_item_mock_1
      ->expects($this
      ->any())
      ->method('getItemId')
      ->willReturn(1);
    $job_item_mock_1
      ->expects($this
      ->any())
      ->method('getItemType')
      ->willReturn('node');
    $job_item_mock_2
      ->expects($this
      ->once())
      ->method('setState')
      ->with(JobItemInterface::STATE_ACTIVE);
    $job_item_mock_2
      ->expects($this
      ->once())
      ->method('addTranslatedData');
    $translate_job = $this
      ->getMockBuilder(Job::class)
      ->disableOriginalConstructor()
      ->setMethods([
      'id',
      'getItems',
      'getTranslator',
      'getTranslatorPlugin',
      'getSetting',
      'getSourceLangcode',
      'getTargetLangcode',
      'save',
      'set',
      'get',
      'addMessage',
      'getFieldDefinitions',
    ])
      ->getMock();
    $translate_job
      ->expects($this
      ->any())
      ->method('id')
      ->willReturn(1);
    $translate_job
      ->expects($this
      ->any())
      ->method('getSetting')
      ->willReturn('public');
    $translate_job
      ->expects($this
      ->any())
      ->method('getTranslator')
      ->willReturn($real_job
      ->getTranslator());
    $translate_job
      ->expects($this
      ->any())
      ->method('getTranslatorPlugin')
      ->willReturn($real_job
      ->getTranslatorPlugin());
    $translate_job
      ->expects($this
      ->any())
      ->method('getSourceLangcode')
      ->willReturn('en');
    $translate_job
      ->expects($this
      ->any())
      ->method('getTargetLangcode')
      ->willReturn('de');
    $translate_job
      ->expects($this
      ->any())
      ->method('get')
      ->willReturn($field_item_list);
    $translate_job
      ->expects($this
      ->any())
      ->method('getFieldDefinitions')
      ->willReturn([]);
    $translate_job
      ->expects($this
      ->once())
      ->method('getItems')
      ->willReturn([
      1 => $job_item_mock_1,
      2 => $job_item_mock_2,
    ]);
    $this->translationRequestManagerMock
      ->expects($this
      ->never())
      ->method('commitError');
    $this->translationRequestManagerMock
      ->expects($this
      ->once())
      ->method('getTranslationRequest')
      ->with($translate_job)
      ->willReturn([
      'translationRequestUid' => 'test',
      'fileUri' => 'test_file_uri.xml',
    ]);
    $this->apiWrapperMock
      ->expects($this
      ->once())
      ->method('getApi')
      ->with('file')
      ->willReturn($this->fileApiMock);
    $this->fileApiMock
      ->expects($this
      ->once())
      ->method('downloadFile')
      ->with('test_file_uri.xml', 'de', $this
      ->callback(function ($subject) {
      $params = $subject
        ->exportToArray();
      return $params['retrievalType'] == 'published';
    }))
      ->willReturn('xml');
    $this->pluginMock
      ->expects($this
      ->once())
      ->method('validateImport')
      ->with('public://tmgmt_smartling_translations/test_file_uri.xml', $translate_job)
      ->willReturn(TRUE);
    $this->pluginMock
      ->expects($this
      ->once())
      ->method('import')
      ->with('public://tmgmt_smartling_translations/test_file_uri.xml', $translate_job)
      ->willReturn([
      1 => [],
      2 => [],
    ]);
    $this->translationRequestManagerMock
      ->expects($this
      ->once())
      ->method('commitSuccessfulDownload')
      ->with($translate_job)
      ->willReturn(TRUE);
    tmgmt_smartling_download_file($translate_job);
  }
  /**
   * Download success full flow: download by TMGMT Job and TMGMT Job Item.
   */
  public function testDownloadByTmgmtJobAndTmgmtJobItem() {
    $real_job = $this
      ->createJobWithItems([
      'batch_uid' => 'uid',
      'batch_execute_on_job' => 1,
    ]);
    $field_item_list = $this
      ->getMockBuilder(FieldItemList::class)
      ->disableOriginalConstructor()
      ->setMethods([
      'getValue',
    ])
      ->getMock();
    $field_item_list
      ->expects($this
      ->any())
      ->method('getValue')
      ->willReturn([
      0 => [
        'value' => NULL,
      ],
    ]);
    $job_item_mock_1 = $this
      ->getMockBuilder(JobItem::class)
      ->disableOriginalConstructor()
      ->setMethods([
      'save',
      'id',
      'setState',
      'addTranslatedData',
      'getItemId',
      'getItemType',
    ])
      ->getMock();
    $job_item_mock_1
      ->expects($this
      ->any())
      ->method('id')
      ->willReturn(1);
    $job_item_mock_1
      ->expects($this
      ->any())
      ->method('getItemId')
      ->willReturn(1);
    $job_item_mock_1
      ->expects($this
      ->any())
      ->method('getItemType')
      ->willReturn('node');
    $job_item_mock_1
      ->expects($this
      ->never())
      ->method('setState')
      ->with(JobItemInterface::STATE_ACTIVE);
    $job_item_mock_1
      ->expects($this
      ->never())
      ->method('addTranslatedData');
    $job_item_mock_2 = $this
      ->getMockBuilder(JobItem::class)
      ->disableOriginalConstructor()
      ->setMethods([
      'id',
      'setState',
      'addTranslatedData',
      'getItemId',
      'getItemType',
    ])
      ->getMock();
    $job_item_mock_2
      ->expects($this
      ->any())
      ->method('id')
      ->willReturn(2);
    $job_item_mock_1
      ->expects($this
      ->any())
      ->method('getItemId')
      ->willReturn(1);
    $job_item_mock_1
      ->expects($this
      ->any())
      ->method('getItemType')
      ->willReturn('node');
    $job_item_mock_2
      ->expects($this
      ->once())
      ->method('setState')
      ->with(JobItemInterface::STATE_ACTIVE);
    $job_item_mock_2
      ->expects($this
      ->once())
      ->method('addTranslatedData');
    $translate_job = $this
      ->getMockBuilder(Job::class)
      ->disableOriginalConstructor()
      ->setMethods([
      'id',
      'getItems',
      'getTranslator',
      'getTranslatorPlugin',
      'getSetting',
      'getSourceLangcode',
      'getTargetLangcode',
      'save',
      'set',
      'get',
      'addMessage',
      'getFieldDefinitions',
    ])
      ->getMock();
    $translate_job
      ->expects($this
      ->any())
      ->method('id')
      ->willReturn(1);
    $translate_job
      ->expects($this
      ->any())
      ->method('getSetting')
      ->willReturn('public');
    $translate_job
      ->expects($this
      ->any())
      ->method('getTranslator')
      ->willReturn($real_job
      ->getTranslator());
    $translate_job
      ->expects($this
      ->any())
      ->method('getTranslatorPlugin')
      ->willReturn($real_job
      ->getTranslatorPlugin());
    $translate_job
      ->expects($this
      ->any())
      ->method('getSourceLangcode')
      ->willReturn('en');
    $translate_job
      ->expects($this
      ->any())
      ->method('getTargetLangcode')
      ->willReturn('de');
    $translate_job
      ->expects($this
      ->any())
      ->method('get')
      ->willReturn($field_item_list);
    $translate_job
      ->expects($this
      ->any())
      ->method('getFieldDefinitions')
      ->willReturn([]);
    $translate_job
      ->expects($this
      ->once())
      ->method('getItems')
      ->willReturn([
      1 => $job_item_mock_1,
      2 => $job_item_mock_2,
    ]);
    $this->translationRequestManagerMock
      ->expects($this
      ->never())
      ->method('commitError');
    $this->translationRequestManagerMock
      ->expects($this
      ->once())
      ->method('getTranslationRequest')
      ->with($translate_job)
      ->willReturn([
      'translationRequestUid' => 'test',
      'fileUri' => 'test_file_uri.xml',
    ]);
    $this->apiWrapperMock
      ->expects($this
      ->once())
      ->method('getApi')
      ->with('file')
      ->willReturn($this->fileApiMock);
    $this->fileApiMock
      ->expects($this
      ->once())
      ->method('downloadFile')
      ->with('test_file_uri.xml', 'de', $this
      ->callback(function ($subject) {
      $params = $subject
        ->exportToArray();
      return $params['retrievalType'] == 'published';
    }))
      ->willReturn('xml');
    $this->pluginMock
      ->expects($this
      ->once())
      ->method('validateImport')
      ->with('public://tmgmt_smartling_translations/test_file_uri.xml', $translate_job)
      ->willReturn(TRUE);
    $this->pluginMock
      ->expects($this
      ->once())
      ->method('import')
      ->with('public://tmgmt_smartling_translations/test_file_uri.xml', $translate_job)
      ->willReturn([
      1 => [],
      2 => [],
    ]);
    $this->translationRequestManagerMock
      ->expects($this
      ->once())
      ->method('commitSuccessfulDownload')
      ->with($translate_job)
      ->willReturn(TRUE);
    tmgmt_smartling_download_file($translate_job, $job_item_mock_2);
  }
}Members
| Name   | Modifiers | Type | Description | Overrides | 
|---|---|---|---|---|
| AssertContentTrait:: | protected | property | The current raw content. | |
| AssertContentTrait:: | protected | property | The drupalSettings value from the current raw $content. | |
| AssertContentTrait:: | protected | property | The XML structure parsed from the current raw $content. | 1 | 
| AssertContentTrait:: | protected | property | The plain-text content of raw $content (text nodes). | |
| AssertContentTrait:: | protected | function | Passes if the raw text IS found escaped on the loaded page, fail otherwise. | |
| AssertContentTrait:: | protected | function | Asserts that a field exists with the given name or ID. | |
| AssertContentTrait:: | protected | function | Asserts that a field exists with the given ID and value. | |
| AssertContentTrait:: | protected | function | Asserts that a field exists with the given name and value. | |
| AssertContentTrait:: | protected | function | Asserts that a field exists in the current page by the given XPath. | |
| AssertContentTrait:: | protected | function | Asserts that a checkbox field in the current page is checked. | |
| AssertContentTrait:: | protected | function | Asserts that a field exists in the current page with a given Xpath result. | |
| AssertContentTrait:: | protected | function | Passes if a link with the specified label is found. | |
| AssertContentTrait:: | protected | function | Passes if a link containing a given href (part) is found. | |
| AssertContentTrait:: | protected | function | Asserts that each HTML ID is used for just a single element. | |
| AssertContentTrait:: | protected | function | Passes if the raw text IS NOT found escaped on the loaded page, fail otherwise. | |
| AssertContentTrait:: | protected | function | Asserts that a field does not exist with the given name or ID. | |
| AssertContentTrait:: | protected | function | Asserts that a field does not exist with the given ID and value. | |
| AssertContentTrait:: | protected | function | Asserts that a field does not exist with the given name and value. | |
| AssertContentTrait:: | protected | function | Asserts that a field does not exist or its value does not match, by XPath. | |
| AssertContentTrait:: | protected | function | Asserts that a checkbox field in the current page is not checked. | |
| AssertContentTrait:: | protected | function | Passes if a link with the specified label is not found. | |
| AssertContentTrait:: | protected | function | Passes if a link containing a given href (part) is not found. | |
| AssertContentTrait:: | protected | function | Passes if a link containing a given href is not found in the main region. | |
| AssertContentTrait:: | protected | function | Asserts that a select option in the current page does not exist. | |
| AssertContentTrait:: | protected | function | Asserts that a select option in the current page is not checked. | |
| AssertContentTrait:: | protected | function | Triggers a pass if the perl regex pattern is not found in raw content. | |
| AssertContentTrait:: | protected | function | Passes if the raw text is NOT found on the loaded page, fail otherwise. | |
| AssertContentTrait:: | protected | function | Passes if the page (with HTML stripped) does not contains the text. | |
| AssertContentTrait:: | protected | function | Pass if the page title is not the given string. | |
| AssertContentTrait:: | protected | function | Passes if the text is found MORE THAN ONCE on the text version of the page. | |
| AssertContentTrait:: | protected | function | Asserts that a select option in the current page exists. | |
| AssertContentTrait:: | protected | function | Asserts that a select option with the visible text exists. | |
| AssertContentTrait:: | protected | function | Asserts that a select option in the current page is checked. | |
| AssertContentTrait:: | protected | function | Asserts that a select option in the current page is checked. | |
| AssertContentTrait:: | protected | function | Asserts that a select option in the current page exists. | |
| AssertContentTrait:: | protected | function | Triggers a pass if the Perl regex pattern is found in the raw content. | |
| AssertContentTrait:: | protected | function | Passes if the raw text IS found on the loaded page, fail otherwise. | |
| AssertContentTrait:: | protected | function | Passes if the page (with HTML stripped) contains the text. | |
| AssertContentTrait:: | protected | function | Helper for assertText and assertNoText. | |
| AssertContentTrait:: | protected | function | Asserts that a Perl regex pattern is found in the plain-text content. | |
| AssertContentTrait:: | protected | function | Asserts themed output. | |
| AssertContentTrait:: | protected | function | Pass if the page title is the given string. | |
| AssertContentTrait:: | protected | function | Passes if the text is found ONLY ONCE on the text version of the page. | |
| AssertContentTrait:: | protected | function | Helper for assertUniqueText and assertNoUniqueText. | |
| AssertContentTrait:: | protected | function | Builds an XPath query. | |
| AssertContentTrait:: | protected | function | Helper: Constructs an XPath for the given set of attributes and value. | |
| AssertContentTrait:: | protected | function | Searches elements using a CSS selector in the raw content. | |
| AssertContentTrait:: | protected | function | Get all option elements, including nested options, in a select. | |
| AssertContentTrait:: | protected | function | Gets the value of drupalSettings for the currently-loaded page. | |
| AssertContentTrait:: | protected | function | Gets the current raw content. | |
| AssertContentTrait:: | protected | function | Get the selected value from a select field. | |
| AssertContentTrait:: | protected | function | Retrieves the plain-text content from the current raw content. | |
| AssertContentTrait:: | protected | function | Get the current URL from the cURL handler. | 1 | 
| AssertContentTrait:: | protected | function | Parse content returned from curlExec using DOM and SimpleXML. | |
| AssertContentTrait:: | protected | function | Removes all white-space between HTML tags from the raw content. | |
| AssertContentTrait:: | protected | function | Sets the value of drupalSettings for the currently-loaded page. | |
| AssertContentTrait:: | protected | function | Sets the raw content (e.g. HTML). | |
| AssertContentTrait:: | protected | function | Performs an xpath search on the contents of the internal browser. | |
| AssertHelperTrait:: | protected static | function | Casts MarkupInterface objects into strings. | |
| AssertLegacyTrait:: | protected | function | Deprecated Scheduled for removal in Drupal 10.0.0. Use self::assertTrue() instead. | |
| AssertLegacyTrait:: | protected | function | Deprecated Scheduled for removal in Drupal 10.0.0. Use self::assertEquals() instead. | |
| AssertLegacyTrait:: | protected | function | Deprecated Scheduled for removal in Drupal 10.0.0. Use self::assertSame() instead. | |
| AssertLegacyTrait:: | protected | function | Deprecated Scheduled for removal in Drupal 10.0.0. Use self::assertEquals() instead. | |
| AssertLegacyTrait:: | protected | function | Deprecated Scheduled for removal in Drupal 10.0.0. Use self::assertNotEquals() instead. | |
| AssertLegacyTrait:: | protected | function | Deprecated Scheduled for removal in Drupal 10.0.0. Use self::assertNotSame() instead. | |
| AssertLegacyTrait:: | protected | function | Deprecated Scheduled for removal in Drupal 10.0.0. Use self::assertTrue() instead. | |
| AssertLegacyTrait:: | protected | function | ||
| ConfigTestTrait:: | protected | function | Returns a ConfigImporter object to import test configuration. | |
| ConfigTestTrait:: | protected | function | Copies configuration objects from source storage to target storage. | |
| DownloadFlowTest:: | public | function | Download success full flow: download by TMGMT Job (all TMGMT Job Items). | |
| DownloadFlowTest:: | public | function | Download success full flow: download by TMGMT Job and TMGMT Job Item. | |
| DownloadFlowTest:: | public | function | Download fail flow. | |
| DownloadFlowTest:: | public | function | Download fail flow: get translation request failed. | |
| DownloadFlowTest:: | public | function | Download fail flow: import failed. | |
| DownloadFlowTest:: | public | function | Download fail flow: validation failed. | |
| DownloadFlowTest:: | public | function | Download success full flow. | |
| DownloadFlowTest:: | public | function | Download success partial flow: import skipped. | |
| KernelTestBase:: | protected | property | Back up and restore any global variables that may be changed by tests. | |
| KernelTestBase:: | protected | property | Back up and restore static class properties that may be changed by tests. | |
| KernelTestBase:: | protected | property | Contains a few static class properties for performance. | |
| KernelTestBase:: | protected | property | ||
| KernelTestBase:: | protected | property | @todo Move into Config test base class. | 7 | 
| KernelTestBase:: | protected static | property | An array of config object names that are excluded from schema checking. | |
| KernelTestBase:: | protected | property | ||
| KernelTestBase:: | protected | property | ||
| KernelTestBase:: | protected | property | Do not forward any global state from the parent process to the processes that run the actual tests. | |
| KernelTestBase:: | protected | property | The app root. | |
| KernelTestBase:: | protected | property | Kernel tests are run in separate processes because they allow autoloading of code from extensions. Running the test in a separate process isolates this behavior from other tests. Subclasses should not override this property. | |
| KernelTestBase:: | protected | property | ||
| KernelTestBase:: | protected | property | Set to TRUE to strict check all configuration saved. | 6 | 
| KernelTestBase:: | protected | property | The virtual filesystem root directory. | |
| KernelTestBase:: | protected | function | 1 | |
| KernelTestBase:: | protected | function | Bootstraps a basic test environment. | |
| KernelTestBase:: | private | function | Bootstraps a kernel for a test. | |
| KernelTestBase:: | protected | function | Configuration accessor for tests. Returns non-overridden configuration. | |
| KernelTestBase:: | protected | function | Disables modules for this test. | |
| KernelTestBase:: | protected | function | Enables modules for this test. | |
| KernelTestBase:: | protected | function | Gets the config schema exclusions for this test. | |
| KernelTestBase:: | protected | function | Returns the Database connection info to be used for this test. | 1 | 
| KernelTestBase:: | public | function | ||
| KernelTestBase:: | private | function | Returns Extension objects for $modules to enable. | |
| KernelTestBase:: | private static | function | Returns the modules to enable for this test. | |
| KernelTestBase:: | protected | function | Initializes the FileCache component. | |
| KernelTestBase:: | protected | function | Installs default configuration for a given list of modules. | |
| KernelTestBase:: | protected | function | Installs the storage schema for a specific entity type. | |
| KernelTestBase:: | protected | function | Installs database tables from a module schema definition. | |
| KernelTestBase:: | protected | function | Returns whether the current test method is running in a separate process. | |
| KernelTestBase:: | protected | function | ||
| KernelTestBase:: | public | function | Registers test-specific services. Overrides ServiceProviderInterface:: | 26 | 
| KernelTestBase:: | protected | function | Renders a render array. | 1 | 
| KernelTestBase:: | protected | function | Sets the install profile and rebuilds the container to update it. | |
| KernelTestBase:: | protected | function | Sets an in-memory Settings variable. | |
| KernelTestBase:: | public static | function | 1 | |
| KernelTestBase:: | protected | function | Sets up the filesystem, so things like the file directory. | 2 | 
| KernelTestBase:: | protected | function | Stops test execution. | |
| KernelTestBase:: | public | function | @after | |
| KernelTestBase:: | protected | function | Dumps the current state of the virtual filesystem to STDOUT. | |
| KernelTestBase:: | public | function | BC: Automatically resolve former KernelTestBase class properties. | |
| KernelTestBase:: | public | function | Prevents serializing any properties. | |
| PhpunitCompatibilityTrait:: | public | function | Returns a mock object for the specified class using the available method. | |
| PhpunitCompatibilityTrait:: | public | function | Compatibility layer for PHPUnit 6 to support PHPUnit 4 code. | |
| RandomGeneratorTrait:: | protected | property | The random generator. | |
| RandomGeneratorTrait:: | protected | function | Gets the random generator for the utility methods. | |
| RandomGeneratorTrait:: | protected | function | Generates a unique random string containing letters and numbers. | 1 | 
| RandomGeneratorTrait:: | public | function | Generates a random PHP object. | |
| RandomGeneratorTrait:: | public | function | Generates a pseudo-random string of ASCII characters of codes 32 to 126. | |
| RandomGeneratorTrait:: | public | function | Callback for random string validation. | |
| SmartlingTestBase:: | protected | property | ||
| SmartlingTestBase:: | protected | property | ||
| SmartlingTestBase:: | protected | property | ||
| SmartlingTestBase:: | protected | property | ||
| SmartlingTestBase:: | public static | property | Modules to enable. Overrides TMGMTKernelTestBase:: | 1 | 
| SmartlingTestBase:: | protected | property | ||
| SmartlingTestBase:: | protected | property | ||
| SmartlingTestBase:: | protected | function | Creates a job. | |
| SmartlingTestBase:: | protected | function | Invokes private or protected method. | |
| SmartlingTestBase:: | public | function | Overrides TMGMTKernelTestBase:: | |
| SmartlingTestBase:: | protected | function | Overrides KernelTestBase:: | |
| StorageCopyTrait:: | protected static | function | Copy the configuration from one storage to another and remove stale items. | |
| TestRequirementsTrait:: | private | function | Checks missing module requirements. | |
| TestRequirementsTrait:: | protected | function | Check module requirements for the Drupal use case. | 1 | 
| TestRequirementsTrait:: | protected static | function | Returns the Drupal root directory. | |
| TMGMTKernelTestBase:: | protected | property | A default translator using the test translator. | |
| TMGMTKernelTestBase:: | function | Sets the proper environment. | ||
| TMGMTKernelTestBase:: | function | Asserts job item language codes. | ||
| TMGMTKernelTestBase:: | protected | function | Creates, saves and returns a translation job. | |
| TMGMTKernelTestBase:: | function | Creates, saves and returns a translator. | 
