Security News
cURL Project and Go Security Teams Reject CVSS as Broken
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
@mmisty/cypress-allure-adapter
Advanced tools
cypress allure adapter to generate allure results during tests execution
This is allure adapter for cypress providing realtime results. It is useful when using Allure TestOps - so you can watch tests execution. It adds tests, steps, suites and screenshots during tests execution.
Note: Video uploads doesn't work well yet since video is being generated after all tests in spec are finished.
Some settings were taken from @shelex/cypress-allure-plugin
Install adapter by npm i -D @mmisty/cypress-allure-adapter
Setup:
Update support: add allureAdapterSetup();
in your support/index.ts
file (or e2e.ts
file)
import { allureAdapterSetup } from '@mmisty/cypress-allure-adapter';
allureAdapterSetup();
Update plugins: add configureAllureAdapterPlugins(on, config);
into your plugins file:
// cypress.config.ts
import { configureAllureAdapterPlugins } from '@mmisty/cypress-allure-adapter/plugins';
export default defineConfig({
e2e: {
setupNodeEvents(on, config) {
configureAllureAdapterPlugins(on, config);
return config;
},
// ...
}
});
Update environment variables: in cypress.config.ts
or in your env files:
allure
=> true
- will enable reporting
allureResults
=> allure-results
- path to allure-results (default 'allure-results')
allureResultsWatchPath
=> path to folder where results will be moved after spec is
done (if you use Allure TestOps specify this path to watch), but default this is not specified
When you use this path tests will start to appear in Allure TestOps only after spec is finished. If not use this with Allure
TestOps then some videos may not be uploaded. Will be uploaded only for 1 test from spec.
allureCleanResults
=> true
- will remove allure results on cypress start
allureSkipCommands
=> wrapNoLog,sync
- commands that will not be logged, separated with comma
allureAttachRequests
=> true
- attach request/response body and status
allureAddVideoOnPass
=> true
- attach video for all tests (including passed), otherwise attach only for failed, broken, unknown
allureShowDuplicateWarn
=> true
- show console warnings about test duplicates, default false
tmsPrefix
and issuePrefix
- you can specify prefix to tms using this.
Also link can be specified with *
- it will be replced with id.
// cypress.config.ts
env: {
tmsPrefix: 'http://jira.com'
issuePrefix: 'http://jira.com/PROJECT-1/*/browse'
}
// test.spec.ts
cy.allure().tms('ABC-1'); // http://jira.com/ABC-1
cy.allure().issue('ABC-2'); // http://jira.com/PROJECT-1/ABC-2/browse
EXAMPLE:
env: {
allure: 'true',
allureResults: 'allure-results',
allureCleanResults: 'true',
allureSkipCommands: 'wrapNoLog,sync', // separated comma
// ... other env varialbles
}
no need to setup types - should be done automatically
To see Allure report locally after tests were executed install allure-commandline
: npm i -D allure-commandline
and run command allure serve
If you are using Cypress action after:spec
in plugins you
can use the following configuration to have video attached to tests:
// cypress.config.ts
import { configureAllureAdapterPlugins } from '@mmisty/cypress-allure-adapter/plugins';
export default defineConfig({
e2e: {
setupNodeEvents(on, config) {
const reporter = configureAllureAdapterPlugins(on, config);
on('after:spec', (spec, results) => {
// your code in after spec
reporter.afterSpec({ results });
})
return config;
},
// ...
}
});
If you need to add labels, tags or other meta info for tests you can use the following events:
test:started
is fired after tests started but before all "before each" hookstest:ended
is fired after all "after each" hooksCypress.Allure.on('test:started', test => {
Cypress.Allure.label('tag', 'started');
});
And also if you need to do something with test before it ends:
Cypress.Allure.on('test:ended', test => {
Cypress.Allure.label('tag', 'ended');
Cypress.Allure.step('before end step');
});
You can put this into your support/index.ts
file.
The following commands available from tests with cy.allure()
or through Cypress.Allure
interface:
/**
* Adds label to test result
* @param name - label name
* @param value - label value
* @example
* cy.allure().label('tag', '@P1');
*/
label(name: string, value: string): T;
/**
* Starts step
* @param name - step name
* @example
* cy.allure().startStep('should login');
*/
startStep(name: string): T;
/**
* Ends current step
* @example
* cy.allure().endStep();
*/
endStep(): T;
/**
* Created finished step
* @example
* cy.allure().step('should login');
*/
step(name: string): T;
/**
* Adds tags to test
* @param tags
* @example
* cy.allure().tag('@regression', '@P1');
*/
tag(...tags: string[]): T;
/**
* Adds severity to test
* @param level 'blocker' | 'critical' | 'normal' | 'minor' | 'trivial';
* @example
* cy.allure().severity('blocker');
*/
severity(level: Severity): T;
/**
* Adds thread to test
* @param value string to group in timeline
* @example
* cy.allure().thread('01');
*/
thread(value: string): T;
/**
* Sets test full name
* @param value string to group in timeline
* @example
* cy.allure().fullName('authentication: should login');
*/
fullName(value: string): T;
/**
* Sets label 'owner' - will be shown in allure report as Owner field
* @param value owner name
* @example
* cy.allure().owner('TP');
*/
owner(value: string): T;
/**
* Sets label 'lead'
* @param value lead name
* @example
* cy.allure().lead('TP');
*/
lead(value: string): T;
/**
* Sets label 'host'
* @param value host name
* @example
* cy.allure().host('MAC-01');
*/
host(value: string): T;
/**
* Sets label 'layer'
* @param value layer name
* @example
* cy.allure().host('MAC-01');
*/
layer(value: string): T;
/**
* Sets label 'browser'
* @param value layer name
* @example
* cy.allure().browser('chrome');
*/
browser(value: string): T;
/**
* Sets label 'device'
* @param value layer name
* @example
* cy.allure().device('MAC-01');
*/
device(value: string): T;
/**
* Sets label 'os'
* @param value os name
* @example
* cy.allure().os('ubuntu');
*/
os(value: string): T;
epic(value: string): T;
link(url: string, name?: string, type?: LinkType): T;
tms(url: string, name?: string): T;
issue(url: string, name?: string): T;
feature(value: string): T;
story(value: string): T;
allureId(value: string): T;
language(value: string): T;
parameter(name: string, value: string): T;
parameters(...params: Parameter[]): T;
testParameter(name: string, value: string): T;
/**
* Sets test status. In some cases you may need to change test status
* @param result - 'passed' | 'failed' | 'skipped' | 'broken' | 'unknown';
* @param details - status details - optional
* @param details.message - message that is shown in report for test
* @param details.trace - stack trace
* @example
* cy.allure().testStatus('broken', { message: 'review test' });
*/
testStatus(result: Status, details?: StatusDetails): T;
/**
* Sets test details - In some cases you may need to change test details message
* @param details - status details
* @param details.message - message that is shown in report for test
* @param details.trace - stack trace
* @example
* cy.allure().testDetails({ message: 'review test' });
*/
testDetails(details: StatusDetails): T;
/**
* Adds attachment to current test
* @param name attachment name
* @param content - contents of attachmnet
* @param type - content type
*/
testAttachment(name: string, content: Buffer | string, type: ContentType): T;
/**
* Adds file attachment to current test
* @param name attachment name
* @param file - path to file
* @param type - content type
*/
testFileAttachment(name: string, file: string, type: ContentType): T;
/**
* Adds attachment to current executable (step, hook or test)
* @param name attachment name
* @param content - contents of attachmnet
* @param type - content type
*/
attachment(name: string, content: Buffer | string, type: ContentType): T;
/**
* Adds file attachment to current executable (step, hook or test)
* @param name attachment name
* @param file - path to file
* @param type - content type
*/
fileAttachment(name: string, file: string, type: ContentType): T;
/**
* Add description HTML
* Will concatenate all descriptions
* @param value - html string
* @example
* cy.allure().addDescriptionHtml('<b>description</b>')
*/
addDescriptionHtml(value: string): T;
/**
* Writes environment info file into allure results path
* @param info - dictionary
* @example
* cy.allure().writeEnvironmentInfo({
* OS: 'ubuntu',
* commit: 'fix of defect 1'
* })
*/
writeEnvironmentInfo(info: EnvironmentInfo): T;
/**
* Writes executor info file into allure results path
* @param info - dictionary
* @example
* cy.allure().writeExecutorInfo({
* name: '1',
* type: 'wwew',
* url: 'http://build',
* buildOrder: 1,
* buildName: 'build name',
* buildUrl: 'http://build.url',
* reportUrl: 'http://report/1',
* reportName: 'report 1',
* });
*/
writeExecutorInfo(info: ExecutorInfo): T;
/**
* Writes categories definitions file into allure results path
* @param categories - Categories to write
*/
writeCategoriesDefinitions(categories: Category[]): T;
/**
* Delete allure-results
*/
deleteResults(): T;
To see debug log run cypress with DEBUG env variable like: DEBUG=cypress-allure* npm run cy:open
Initial version
0.6.0
FAQs
cypress allure adapter to generate allure results during tests execution (Allure TestOps compatible)
We found that @mmisty/cypress-allure-adapter 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
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.
Security News
Biden's executive order pushes for AI-driven cybersecurity, software supply chain transparency, and stronger protections for federal and open source systems.