Security News
New Python Packaging Proposal Aims to Solve Phantom Dependency Problem with SBOMs
PEP 770 proposes adding SBOM support to Python packages to improve transparency and catch hidden non-Python dependencies that security tools often miss.
@testomatio/reporter
Advanced tools
Library for sending test run reports to your testomat.io project.
Get the {API_KEY}
from testomat.
You can refer sample tests from example folder of this repo. This is a basic example. If you need something full fledged you can refer this example repo.
Add @testomatio/reporter
package to your project:
npm i @testomatio/reporter --save
For testcafe use testcafe reporter:
npm i testcafe-reporter-testomatio
Make sure you load all your tests using check-test.
Add plugin to codecept conf:
plugins: {
testomatio: {
enabled: true,
require: '@testomatio/reporter/lib/adapter/codecept',
apiKey: process.env.TESTOMATIO || 'API_KEY', // pass in api key via config or env variable
}
}
Run the following command from you project folder:
TESTOMATIO={API_KEY} npx codeceptjs run
If tests run parallel, like workers in CodeceptJS use start-test-run
command to get proper reports:
TESTOMATIO={API_KEY} npx start-test-run -c 'npx codeceptjs run-workers 2'
Specify a command to run with
-c
option instart-test-run
Add a reporter to Playwright config:
reporter: [
['list'],
[
'@testomatio/reporter/lib/adapter/playwright.js',
{
apiKey: process.env.TESTOMATIO,
},
],
];
Run the following command from you project folder:
TESTOMATIO={API_KEY} npx playwright test
Load the test using using check-test
if not done already. Get the test id from testomat account and add it to your mocha test like in this example.
Run the following command from you project folder:
mocha --reporter ./node_modules/testomat-reporter/lib/adapter/mocha.js --reporter-options apiKey={API_KEY}
Load the test using using check-test
. Add the test id to your tests like in this example.
Add the following line to jest.config.js:
reporters: ['default', ['@testomatio/reporter/lib/adapter/jest.js', { apiKey: process.env.TESTOMATIO }]],
Run your tests.
Load you test using check-cucumber
.
Run the following command from you project folder:
TESTOMATIO={API_KEY} ./node_modules/.bin/cucumber-js --format ./node_modules/@testomatio/reporter/lib/adapter/cucumber.js
Load the test using using check-test
.
Run the following command from you project folder:
TESTOMATIO={API_KEY} npx testcafe chrome -r testomatio
Load the test using using check-test
.
Register our cypress-plugin
in cypress/plugins/index.js
:
const testomatioReporter = require('@testomatio/reporter/lib/adapter/cypress-plugin');
/**
* @type {Cypress.PluginConfig}
*/
module.exports = (on, config) => {
// `on` is used to hook into various events Cypress emits
// `config` is the resolved Cypress config
testomatioReporter(on, config);
return config;
};
Run the following command from you project folder:
TESTOMATIO={API_KEY} npx cypress run
Load the test using using check-test
.
Add the following lines to conf.js:
const JasmineReporter = require('@testomatio/reporter/lib/adapter/jasmine');
exports.config = {
onPrepare: () => {
jasmine.getEnv().addReporter(new JasmineReporter({ apiKey: process.env.TESTOMATIO }));
},
};
Run the following command from you project folder:
TESTOMATIO={API_KEY} npx @testomatio/reporter@latest -c 'npx protractor conf.js'
Load the test using using check-test
.
Add the following lines to wdio.conf.js:
const testomatio = require('@testomatio/reporter/lib/adapter/webdriver');
exports.config = {
// ...
reporters: [
[testomatio, {
apiKey: $ {
process.env.TESTOMATIO
}
}]
]
}
Run the following command from you project folder:
TESTOMATIO={API_KEY} npx @testomatio/reporter -c 'npx wdio wdio.conf.js'
Testomat.io will not create tests from the report if they have not been previously imported. To create tests during the report TESTOMATIO_CREATE
option can be used:
TESTOMATIO={API_KEY} TESTOMATIO_CREATE=1 <actual run command>
This feature is widely used when a run is executed on CI.
A run is created before the test is started and it is marked as scheduled
. Then
a report is assigned to that run using TESTOMATIO_RUN
environment variable and {RUN_ID}
of a run:
TESTOMATIO={API_KEY} TESTOMATIO_RUN={RUN_ID} <actual run command>
Give a title to your reports by passing it as environment variable to TESTOMATIO_TITLE
.
TESTOMATIO={API_KEY} TESTOMATIO_TITLE="title for the report" <actual run command>
Create/Add run to group by providing TESTOMATIO_RUNGROUP_TITLE
:
TESTOMATIO={API_KEY} TESTOMATIO_RUNGROUP_TITLE="Build ${BUILD_ID}" <actual run command>
Add environments to run by providing TESTOMATIO_ENV
as comma seperated values:
TESTOMATIO={API_KEY} TESTOMATIO_ENV="Windows, Chrome" <actual run command>
To save a test artifacts (screenshots and videos) of a failed test use S3 storage. Please note, that the storage is not connected to Testomatio. This allows you to store your artifacts on your own account and not expose S3 credentials.
To save screenshots provide a configuration for S3 bucket via environment variables:
By default tests artifacts are uploaded to bucket with public-read
permission.
In this case uploaded files will be publicly accessible in Internet.
These public links will be used by testomat.io to display images and videos.
To upload files with private
access bucket add TESTOMATIO_PRIVATE_ARTIFACTS=1
environment value.
Then update provide the same S3 credentials in "Settings > Artifacts" section of a testomat.io project,
so testomat.io could connect to the same bucket and fetch uploaded artifacts.
Links to files will be pre-signed and expires automatically in 10 minutes.
Example upload configuration in environment variables:
TESTOMATIO_PRIVATE_ARTIFACTS=1
S3_ACCESS_KEY_ID=11111111111111111111
S3_SECRET_ACCESS_KEY=2222222222222222222222222222222222222222222
S3_BUCKET=artifacts
S3_REGION=us-west-1
TESTOMATIO_PRIVATE_ARTIFACTS=1
S3_ENDPOINT=https://ams3.digitaloceanspaces.com
S3_ACCESS_KEY_ID=11111111111111111111
S3_SECRET_ACCESS_KEY=2222222222222222222222222222222222222222222
S3_BUCKET=artifacts
S3_REGION=ams3
S3_ENDPOINT=http://company.storage.com
S3_ACCESS_KEY_ID=minio
S3_SECRET_ACCESS_KEY=minio123
S3_BUCKET=testomatio
S3_FORCE_PATH_STYLE=true
It is important to add S3_FORCE_PATH_STYLE var for minio setup
For local testing, it is recommended to store this configuration in .env
file and load it with dotenv library.
On CI set environment variables in CI config.
Test artifacts are automatically uploaded for these test runners:
To manually attach an artifact and upload it for a test use global.testomatioArtifacts
array:
// attach a picture inside a test
global.testomatioArtifacts.push('img/file.png');
// attach a picture and add a name to it
global.testomatioArtifacts.push({ name: 'Screenshot', path: 'img/file.png' });
Artifacts will be uploaded for the current test when it is finished.
To disable uploading artifacts add TESTOMATIO_DISABLE_ARTIFACTS
environment variable:
TESTOMATIO_DISABLE_ARTIFACTS=1
If you want to create a run and obtain its {RUN_ID}
from testomat.io you can use --launch
option:
TESTOMATIO={API_KEY} npx @testomatio/reporter@latest --launch
This command will return {RUN_ID}
which you can pass to other testrunner processes.
When executed with
--launch
a command provided by-c
flag is ignored
If you want to finish a run started by --launch
use --finish
option. TESTOMATIO_RUN
environment variable is required:
TESTOMATIO={API_KEY} TESTOMATIO_RUN={RUN_ID} npx @testomatio/reporter@latest --finish
FAQs
Testomatio Reporter Client
The npm package @testomatio/reporter receives a total of 14,930 weekly downloads. As such, @testomatio/reporter popularity was classified as popular.
We found that @testomatio/reporter demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
PEP 770 proposes adding SBOM support to Python packages to improve transparency and catch hidden non-Python dependencies that security tools often miss.
Security News
Socket CEO Feross Aboukhadijeh discusses open source security challenges, including zero-day attacks and supply chain risks, on the Cyber Security Council podcast.
Security News
Research
Socket researchers uncover how threat actors weaponize Out-of-Band Application Security Testing (OAST) techniques across the npm, PyPI, and RubyGems ecosystems to exfiltrate sensitive data.