Example Module test
Let’s assume the example module is installed in your shop, Codeceptions initialization is done as described and you’d like to write a Codeception acceptance test verifying that you see a “Hello, my shopid is 1” on the shop’s start page with activated module.
Create a Cest
You can create a Cest by running the following command from inside the module Tests
directory (<vendor_name>/<module_name>/Tests
):
<shop_dir>/vendor/bin/codecept generate:cest acceptance CheckShopFrontend
The empty <vendor_name>/<module_name>/Tests/Codeception/Acceptance/CheckShopFrontendCest.php
Cest will be
automatically created.
<?php
class CheckShopFrontendCest
{
public function _before(AcceptanceTester $I)
{
}
// tests
public function tryToTest(AcceptanceTester $I)
{
}
}
It is not yet testing anything, but we can already run it. Running the codeception tests is explained in section Running Codeception Tests.
Add test for not logged in user case
Let us add test code to check the front page.
<?php
namespace MyVendor\MyModule\Tests\Codeception;
use MyVendor\MyModule\Tests\Codeception\AcceptanceTester;
class CheckShopFrontendCest
{
public function _before(AcceptanceTester $I)
{
}
// tests
public function notLoggedInUserMessage(AcceptanceTester $I)
{
$I->wantToTest('message for not logged in user');
$I->amOnPage('/');
$I->see('Hello, my shopid is 1!');
}
}
Running the test should look like
vagrant@oxideshop:/var/www/oxideshop$ vendor/bin/runtests-codeception
Building Actor classes for suites: acceptance
-> AcceptanceTesterActions.php generated successfully. 150 methods added
\AcceptanceTester includes modules: Asserts, WebDriver, Db, \OxidEsales\Codeception\Module\Oxideshop, \OxidEsales\Codeception\Module\Database, \OxidEsales\Codeception\Module\Translation\TranslationsModule
Codeception PHP Testing Framework v2.5.6
Powered by PHPUnit 6.5.14 by Sebastian Bergmann and contributors.
Running with seed:
Acceptance Tests (1) ----------------------------------------------------------------------------------------------------------------------------------------------
✔ CheckShopFrontendCest: Test message for not logged in user (8.72s)
-------------------------------------------------------------------------------------------------------------------------------------------------------------------
Time: 55.12 seconds, Memory: 12.00MB
OK (1 test, 1 assertion)
- XML report generated in file:///var/www/oxideshop/source/modules/myvendor/mymodule/tests/Codeception/_output/report.xml
Add test for logged in user case
Now let’s check the case of a logged in user. See here for test user credentials.
We will need to:
open the shop
open the login box
enter user credentials
check the main page for the expected message.
Some of those steps can be skipped by using OXID Codeception Page Objects.
To be able to use the OXID page objects, first, OXID Codeception Modules need to be enabled in your module codeception configuration. When initializing the codeception tests as described in section Creating test structure in a module this is already taken care of. Let’s just add the next test:
public function loggedInUserMessage(AcceptanceTester $I)
{
$I->wantToTest('different message for logged in user');
$homePage = new \OxidEsales\Codeception\Page\Home($I);
$I->amOnPage($homePage->URL);
$I->see('Hello, my shopid is 1!');
$homePage->loginUser('user@oxid-esales.com', 'useruser');
$I->dontSee(\OxidEsales\Codeception\Module\Translation\Translator::translate('LOGIN'));
$I->see('Hello, my shopid is 1 and you are ' . 'user@oxid-esales.com' . ' ;)');
}
So now instead of manually trying to figure out all locators, forms, buttons, we just use the
\OxidEsales\Codeception\Page\Home
PageObject which is providing all this wrapped up in method loginUser
.
In this test we can also see an example of using the OXID's Codeception Translation module
. It will
translate the language constant to be independent from chosen language.
In section Create own PageObject you can find an example how to create your own PageObjects,