This Package allows you to create fast and simple testing environments. It's also used by all pimcore Bundles created by DACHCOM.DIGITAL.
Branch | Supported Pimcore Versions | Supported Symfony Versions |
---|---|---|
3.0 | 11.0 |
^6.2 |
2.0 | 10.1 - 10.6 |
^5.4 |
1.0 | 6.6 - 6.9 |
^4.4 , ^3.4 |
- Yaml extension changed from
yml
toyaml
_support
path has changed toSupport
. AllDachcom\Codeception\*
namespaces have changed toDachcom\Codeception\Support\*
- Using rsync for
setup_files
so you need to adjust yoursetup_files
stack accordingly (see example below) - You need to define PIMCORE
config_location
in your ci configuration (See section "Configuration Location" below) - You have to add additional PIMCORE Bundles to the
bundles
config section (see example below) - [SECURITY]
\Pimcore\Bundle\AdminBundle\EventListener\CsrfProtectionListener
is disabled while executing tests Pimcore\Model\DataObject
namespace changed from_output/var/classes/DataObject/DataObject
to_output/var/classes/DataObject
- TestKernel Class can be defined via
TEST_KERNEL_CLASS
env var
All test files need to be stored in /tests
.
Name | Example | Required | Description |
---|---|---|---|
TEST_BUNDLE_NAME |
ToolboxBundle |
yes | -- |
TEST_BUNDLE_INSTALLER_CLASS |
ToolboxBundle\\Tool\\Install |
yes | Set to false if you don't have any installer class |
TEST_BUNDLE_TEST_DIR |
${{ github.workspace }}/tests |
yes | -- |
TEST_PROJECT_ROOT_DIR |
${{ github.workspace }} |
yes | This variable is required to setup test structure before any system is running |
PIMCORE_CODECEPTION_FRAMEWORK |
${{ github.workspace }}/pimcore-codeception-framework |
yes | -- |
PIMCORE_CODECEPTION_VERSION |
2.0 , 1.0 |
yes | -- |
Create a file called _bootstrap.php
in tests/_bootstrap.php
<?php
$frameworkPath = getenv('PIMCORE_CODECEPTION_FRAMEWORK');
$bundleTestPath = getenv('TEST_BUNDLE_TEST_DIR');
$bootstrap = sprintf('%s/src/_bootstrap.php', $frameworkPath);
include_once $bootstrap;
Create a file called config.yaml
in tests/_etc/config.yaml
.
bundles:
- { namespace: \MyTestBundle\MyTestBundle }
- { namespace: \Pimcore\Bundle\SeoBundle\PimcoreSeoBundle, priority: 0, execute_installer: true } # if you need the seo bundle
setup_files:
- { path: app/config.yaml, dest: ./config/ }
- { path: app/system_settings.yaml, dest: ./var/config/system_settings/ }
- { path: app/controller/DefaultController.php, dest: ./src/Controller/ }
- { path: app/templates/default.html.twig, dest: ./templates/default/ }
- { path: app/templates/snippet.html.twig, dest: ./templates/default/ }
preload_files:
- { path: Services/MySpecialTestService.php }
additional_composer_packages:
- { package: pimcore/admin-ui-classic-bundle, version: ^1.0 } # this one is most likely needed
- { package: vendor/foo-bar, version: ^1.0} # additional packages
In your app/config.yaml
you should move all config locations to settings-store
,
see pimcore ci example
Attention! Do not set
system_settings
tosettings-store
!
- bundles (required): At least your test bundle should be registered here. Add more, if needed
- setup_files (optional): All your template files which should to be available during test cycles. These files need to be
stored under
/tests/_etc/config
- preload_files (optional): These files will be included at kernel setup. Since these files are not included via composer autoload, we need to define them here
- additional_composer_packages (optional): Install additional composer packages which are not available in root composer.json
This Framework allows you to use multiple (bundle) configuration setups. You need to add at least one default config file
called default_config.yaml
and store it in /tests/_etc/config/bundle
.
TBD
If you want to provide some classes to install, all the definitions need to stored at /tests/_etc/classes
.
Name | Description |
---|---|
$I->seeResponseCsvHeaderHasValues(array $headerValues) |
|
$I->seeResponseCsvRowValues(int $index, array $values) |
|
$I->seeResponseCsvLength(int $length) |
|
$I->seeResponseIsCsv() |
Name | Description |
---|---|
$I->seeResponseContainsJson(array $json = []) |
|
$I->seeResponseIsJson() |
Name | Description |
---|---|
$I->haveAPageDocument($key = 'bundle-page-test', array $params = [], $locale = null) |
|
$I->haveASubPageDocument(Document $parent, $key = 'bundle-sub-page-test', array $params = [], $locale = null) |
|
$I->haveTwoConnectedDocuments(Document\Page $sourceDocument, Document\Page $targetDocument) |
|
$I->haveAUnPublishedDocument(Document $document) |
|
$I->moveDocument(Document $document, Document $parentDocument) |
|
$I->haveASnippet($key = 'bundle-snippet-test', $params = [], $locale = null) |
|
$I->haveAEmail($key = 'bundle-email-test', array $params = [], $locale = null) |
|
$I->haveALink(Document\Page $source, $key = 'bundle-link-test', array $params = [], $locale = null) |
|
$I->haveASubLink(Document $parent, Document\Page $source, $key = 'bundle-sub-link-test', array $params = [], $locale = null) |
|
$I->haveAHardLink(Document\Page $source, $key = 'bundle-hardlink-test', array $params = [], $locale = null) |
|
$I->haveASubHardLink(Document $parent, Document\Page $source, $key = 'bundle-sub-hardlink-test', array $params = [], $locale = null) |
|
$I->haveAPimcoreObject(string $objectType, $key = 'bundle-object-test', array $params = []) |
|
$I->haveASubPimcoreObject(DataObject $parent, string $objectType, $key = 'bundle-sub-object-test', array $params = []) |
|
$I->refreshObject(DataObject $object) |
|
$I->moveObject(DataObject $object, DataObject $parentObject) |
|
$I->copyObject(DataObject $object, DataObject $targetObject) |
|
$I->createNewObjectVersion(DataObject\Concrete $object) |
|
$I->deleteObjectVersion(Version $version) |
|
$I->publishObjectVersion(Version $version) |
|
$I->moveObjectToRecycleBin(DataObject $object) |
|
$I->restoreObjectFromRecycleBin(DataObject $object, Item $item) |
|
$I->haveAPimcoreObjectFolder($key = 'bundle-object-folder-test', array $params = []) |
|
$I->haveAPimcoreAsset($key = 'bundle-asset-test', array $params = []) |
|
$I->haveASubPimcoreAsset(Asset\Folder $parent, $key = 'bundle-sub-asset-test', array $params = []) |
|
$I->haveAPimcoreAssetFolder($key = 'bundle-asset-folder-test', array $params = []) |
|
$I->haveASubPimcoreAssetFolder(Asset\Folder $parent, $key = 'bundle-asset-sub-folder-test', array $params = []) |
|
$I->moveAsset(Asset $asset, Asset $parentAsset) |
|
$I->haveADummyFile($fileName, $fileSizeInMb = 1) |
|
$I->haveASite($siteKey, array $params = [], $locale = null, $add3w = false, $additionalDomains = [], array $errorDocuments = []) |
|
$I->haveAPageDocumentForSite(Site $site, $key = 'document-test', array $params = [], $locale = null) |
|
$I->haveAHardlinkForSite(Site $site, Document\Page $document, $key = 'hardlink-test', array $params = [], $locale = null) |
|
$I->seeDownload($fileName) |
|
$I->seeEditablesPlacedOnDocument(Document $document, array $editables) |
|
$I->seeAnAreaElementPlacedOnDocument(Document $document, string $areaName, array $editables = []) |
|
$I->seeEmailIsSent(Document\Email $email) |
|
$I->seeEmailIsNotSent(Document\Email $email) |
|
$I->seePropertiesInEmail(Document\Email $mail, array $properties) |
|
$I->seePropertyKeysInEmail(Document\Email $mail, array $properties) |
|
$I->cantSeePropertyKeysInEmail(Document\Email $mail, array $properties) |
|
$I->seeInRenderedEmailBody(Document\Email $mail, string $string) |
|
$I->seeKeyInFrontendTranslations(string $key) |
|
$I->haveAFrontendTranslatedKey(string $key, string $translation, string $language) |
|
$I->haveAStaticRoute(string $name = 'test_route', array $params = []) |
|
$I->haveAPimcoreRedirect(array $data) |
|
$I->haveAPimcoreClass(string $name = 'TestClass') |
|
$I->submitDocumentToXliffExporter(Document $document) |
Name | Description |
---|---|
This module installs a bundle if run_installer option is set to true |
Name | Description |
---|---|
$I->haveABootedSymfonyConfiguration(string $configuration) |
|
$I->haveAKernelWithoutDebugMode() |
|
$I->seeException(string $exception, ?string $message, \Closure $callback) |
Name | Description |
---|---|
$I->haveAUser($username) |
|
$I->haveAUserWithAdminRights($username) |
Name | Description |
---|---|
$I->haveReplacedPimcoreRuntimeConfigurationNode(array $overrideConfig) |
|
$I->amOnPageInEditMode(string $page) |
|
$I->amOnPageWithLocale(string $url, null string array $locale) |
|
$I->amOnPageWithLocaleAndCountry(string $url, ?string $locale, string $country) |
|
$I->seeDownloadLink(AbstractModel $element, string $link) |
|
$I->seeDownloadLinkZip(string $fileName, string $link) |
|
$I->amOnStaticRoute(string $routeName, array $args) |
|
$I->seeCurrentHostEquals(string $host) |
|
$I->seeAEditableConfiguration(string $name, string $type, ?string $label, array $options, $data = null, $selector = null) |
|
$I->seeEmailIsSentTo(string $recipient, Email $email) |
|
$I->seeSentEmailHasPropertyValue(Email $email, string $property, string $value) |
|
$I->seeSentEmailHasHeaderValue(Email $email, string $property, string $value) |
|
$I->seeEmailSubmissionType(string $submissionType, string $type, Email $email) |
|
$I->seeEmptyEmailSubmissionType(string $type, Email $email) |
|
$I->seeInSubmittedEmailBody(string $string, Email $email) |
|
$I->dontSeeInSubmittedEmailBody(string $string, Email $email) |
|
$I->seeInSubmittedEmailBodyOfType(string $string, string $type, Email $email) |
|
$I->dontSeeInSubmittedEmailBodyOfType(string $string, string $type, Email $email) |
|
$I->amLoggedInAsFrontendUser(?UserInterface $user, string $firewallName) |
|
$I->amLoggedInAs(string $username) |
|
$I->sendTokenAjaxPostRequest(string $url, array $params = []) |
|
$I->seeLastRequestIsInPath(string $expectedPath) |
|
$I->seeCanonicalLinkInResponse() |
|
$I->dontSeeCanonicalLinkInResponse() |
|
$I->seePimcoreOutputCacheDisabledHeader(string $disabledReasonMessage) |
|
$I->dontSeePimcoreOutputCacheDisabledHeader() |
|
$I->seePimcoreOutputCacheDate() |
|
$I->seeEmptySessionBag(string $bagName) |
|
$I->seePropertiesInLastFragmentRequest(array $properties = []) |
Name | Description |
---|---|
$I->amOnPageInEditMode(string $page) |
|
$I->setDownloadPathForWebDriver($path = null) |
|
$I->clearWebDriverCache() |
|
$I->seeAEditableConfiguration(string $name, string $type, ?string $label, array $options, $data = null, $selector = null) |
|
$I->sendWebDriverCommand(array $body) |
DACHCOM.DIGITAL AG, Löwenhofstrasse 15, 9424 Rheineck, Schweiz
dachcom.com, dcdi@dachcom.ch
Copyright © 2024 DACHCOM.DIGITAL. All rights reserved.
For licensing details please visit LICENSE.md