2017 © Pedro Peláez
 

library datadir-tests

Tool for functional testing of Keboola Connection components

image

keboola/datadir-tests

Tool for functional testing of Keboola Connection components

  • Monday, July 16, 2018
  • by Keboola
  • Repository
  • 7 Watchers
  • 0 Stars
  • 815 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 0 Forks
  • 1 Open issues
  • 9 Versions
  • 65 % Grown

The README.md

Datadir Tests

GitHub Actions, (*1)

Usage

Require this package in you component, (*2)

composer require keboola/datadir-tests`

In the tests folder create a directory structure mimicking the directory structure in production:, (*3)

/path/to/tests
└─test-name
  ├─expected-code
  ├─expected-stdout (optional)
  ├─expected-stderr (optional)
  ├─expected
  │ └─data
  │   └─out
  │     ├─files
  │     └─tables
  ├─source
  │ └─data
  │   └─in
  │     ├─files
  │     └─tables
  └─config.json

Note: expected-stdout and expected-stderr are compared with real output using assertStringMatchesFormat method, so you can use placeholders., (*4)

Then create empty /path/to/tests/DatadirTest that extends Keboola\DatadirTests\DatadirTestCase:, (*5)

<?php

declare(strict_types=1);

namespace MyComponent\Tests;

use Keboola\DatadirTests\DatadirTestCase;

class DatadirTest extends DatadirTestCase
{
}

Run it using, (*6)

vendor/bin/phpunit /path/to/tests/DatadirTest.php`

The script then executes /code/src/run.php with KBC_DATADIR set to the test directory. There can be any number of test directories and the script automatically discovers them using DatadirTestsFromDirectoryProvider. You can supply your own provider that implements DatadirTestsProviderInterface. It needs to return array of arrays (!) of DatadirTestSpecificationInterface instances., (*7)

When the expected-code file is present, the return code of execution is checked. The file contains a single number number - the execution code, allowed values are 0, 1, 2., (*8)

What is DatadirTestSpecificationInterface?

DatadirTestSpecificationInterface contains all the information you need to create and assert a datadir test: * getSourceDatadirDirectory(): ?string: returns the directory that initializes the test. You should prepare config.json and potentially also /in/files or /in/tables contents. That directory is mirrored to the temporary directory that the test is ran in. null means just barebones directory structure is created and you need to create config.json, etc. in the temporary directory yourself.
* getExpectedReturnCode(): ?int: expected exit code, null means "non-zero" * getExpectedStdout(): ?string: if supplied, whole stdout output is checked against supplied value * getExpectedStderr(): ?string: if supplied, whole stderr output is checked against supplied value * getExpectedOutDirectory(): ?string: if supplied, the temporary directory's out directory is compared with this directory after the component is ran. Any differences result in test failure., (*9)

## Custom test, (*10)

Just add a test method and reuse the existing helper methods in AbstractDatadirTestCase., (*11)

```php public function testInvalidFile(): void { // create specification manually $specification = new DatadirTestSpecification( DIR . '/columns-auto/source/data', 0, null, null, DIR . '/columns-auto/expected/data/out' );, (*12)

// create temporary directory
$tempDatadir = $this->getTempDatadir($specification);

// modify temporary directory however you see fit
file_put_contents($tempDatadir->getTmpFolder() . '/config.json', '{"parameters": []}');

// run the script
$process = $this->runScript($tempDatadir->getTmpFolder());

// assert specification
$this->assertMatchesSpecification($specification, $process, $tempDatadir->getTmpFolder());

} ```, (*13)

Environment variables

  • In config.json you can use placeholders for environment variables.
  • Format is %env(TYPE:VAR_NAME)%, eg. %env(int:DB_PORT)%.
  • All string values in config.json that match specified format are replaced.
  • It is implemented inAbstractDatadirTestCase::modifyConfigJsonContent.
  • Allowed types are string, int, float, bool.
  • See example in the test.

Functionality adjustments

  • To modify temp data dir before execution, you can extend the method AbstractDatadirTestCase::setUpDatadir.

Development

Clone this repository and init the workspace with following command:, (*14)

git clone https://github.com/keboola/datadir-tests
cd datadir-tests
docker-compose run --rm dev /bin/bash
$ composer install
$ composer ci

License

MIT licensed, see LICENSE file., (*15)

The Versions

16/07 2018
04/07 2018

dev-ds-support-exit-code-definition

dev-ds-support-exit-code-definition

Tool for functional testing of Keboola Connection components

  Sources   Download

MIT

The Requires

 

The Development Requires

03/05 2018
03/05 2018

dev-tf2-fix-unexpected-success

dev-tf2-fix-unexpected-success

Tool for functional testing of Keboola Connection components

  Sources   Download

MIT

The Requires

 

The Development Requires

03/05 2018

dev-tf2-tests

dev-tf2-tests

Tool for functional testing of Keboola Connection components

  Sources   Download

MIT

The Requires

 

The Development Requires

16/04 2018
16/04 2018