There are different types of tests executed:
- They utilize Vitest.
- Test files are suffixed with
.spec.ts
.
- Tests implement the act, arrange, and assert (AAA) pattern.
- Arrange
- Sets up the test scenario and environment.
- Begins with comment line
// arrange
.
- Act
- Executes the actual test.
- Begins with comment line
// act
.
- Assert
- Sets an expectation for the test's outcome.
- Begins with comment line
// assert
.
- Evaluate individual components in isolation.
- Located in
./tests/unit
. - Achieve isolation using stubs where you place:
- Common stubs in
./shared/Stubs
, - Component-specific stubs in same folder as test file.
- Common stubs in
- Include Vue component tests, enabled by
@vue/test-utils
.
- Test suites start with a description of the component or system under test.
- E.g., tests for
Application.ts
are contained inApplication.spec.ts
.
- E.g., tests for
- Whenever possible,
describe
blocks group tests of the same function.- E.g., tests for
run()
are insidedescribe('run', () => ...)
.
- E.g., tests for
- Assess the combined functionality of components.
- They verify that third-party dependencies function as anticipated.
- Examine the live web application's functionality and performance.
- Uses Cypress to run the tests.
These checks validate various qualities like runtime execution, building process, security testing, etc.
- Use various tools and scripts.
- Are automatically executed as GitHub workflows.
checks.security.sast
: Utilizes CodeQL to conduct Static Analysis Security Testing (SAST) to ensure the secure integrity of the codebase.checks.security.dependencies
: Performs audits on third-party dependencies to identify and mitigate potential vulnerabilities, safeguarding the project from exploitable weaknesses.
package.json
: Defines test commands and includes tools used in tests.vite.config.ts
: Configuresvitest
for unit and integration tests../src/
: Contains the code subject to testing../tests/shared/
: Contains code shared by different test categories.bootstrap/setup.ts
: Initializes unit and integration tests.Assertions/
: Contains common assertion functions, prefixed withexpect
.
./tests/unit/
- Stores unit test code.
- The directory structure mirrors
./src/
.- E.g., tests for
./src/application/ApplicationFactory.ts
reside in./tests/unit/application/ApplicationFactory.spec.ts
.
- E.g., tests for
shared/
- Contains shared unit test functionalities.
TestCases/
- Shared test cases.
- Functions that calls
it()
from Vitest should haveit
prefix.
Stubs/
: Maintains stubs for component isolation, equipped with basic functionalities and, when necessary, spying or mocking capabilities.
./tests/integration/
: Contains integration test files.cypress.config.ts
: Cypress (E2E tests) configuration file.cypress-dirs.json
: A central definition of directories used by Cypress, designed for reuse across different configurations../tests/e2e/
: Base Cypress folder, includes tests with.cy.ts
extension.- [
/tsconfig.json
]: TypeScript configuration for file Cypress code, improves IDE support, recommended to have by official documentation. - (git ignored)
/videos
: Asset folder for videos taken during tests. - (git ignored)
/screenshots
: Asset folder for Screenshots taken during tests. /support/e2e.ts
: Support file, runs before every single test file./support/interactions/
: Contains reusable functions for simulating user interactions, enhancing test readability and maintainability.
- [