'1', 'field1' => 'f1value1', 'field2' => 'f2value1'], ['key' => '2', 'field1' => 'f1value2', 'field2' => 'f2value2'], ]; $ids = ['key' => ['type' => 'integer']]; $definition = [ 'migration_tags' => ['Embedded data test'], 'source' => [ 'plugin' => 'embedded_data', 'data_rows' => $data_rows, 'ids' => $ids, ], 'process' => [], 'destination' => ['plugin' => 'null'], ]; $migration = \Drupal::service('plugin.manager.migration')->createStubMigration($definition); $source = $migration->getSourcePlugin(); // Validate the plugin returns the source data that was provided. $results = []; /** @var \Drupal\migrate\Row $row */ foreach ($source as $row) { // The plugin should not mark any rows as stubs. We need to use // assertSame() here because assertFalse() will pass falsy values (e.g., // empty arrays). $this->assertSame(FALSE, $row->isStub()); $data_row = $row->getSource(); // The "data" row returned by getSource() also includes all source // configuration - we remove it so we see only the data itself. unset($data_row['plugin']); unset($data_row['data_rows']); unset($data_row['ids']); $results[] = $data_row; } $this->assertIdentical($results, $data_rows); // Validate the public APIs. $this->assertIdentical($source->count(), count($data_rows)); $this->assertIdentical($source->getIds(), $ids); $expected_fields = [ 'key' => 'key', 'field1' => 'field1', 'field2' => 'field2', ]; $this->assertIdentical($source->fields(), $expected_fields); } }