To integrate Playwright with PerfectoSmart Reporting, follow the tasks specific for your chosen programming language. Click the language to expand the steps.
For information on supported operating systems and browsers as well as prerequisites, see Playwright.
 Java
Java
                                                Perform the following steps to add the PerfectoSmart Reporting code to your Playwright test scripts, placing the code snippets at appropriate points in your test flow.
- 
                                                            Add the testStartcode at the beginning of your test script, right after initializing the Playwright and browser context. This marks the start of the test.Copy//test start
 Map<String, Object> paramsTestStart = new HashMap<>();
 paramsTestStart.put("name", "name");
 //tags
 paramsTestStart.put("tags", List.of("tag1", "tag2"));
 //job
 paramsTestStart.put("jobName","My Job");
 paramsTestStart.put("jobNumber",45);
 //project
 paramsTestStart.put("projectName","project name");
 paramsTestStart.put("projectVersion","1.0");
 page.evaluate("perfecto:report:testStart", new Gson().toJson(paramsTestStart));
- 
                                                            Place the stepStartandstepEndcode around the specific steps you want to report. This marks the beginning and end of each step within your test.Copy//step start
 Map<String, Object> paramsStepStart = new HashMap<>();
 paramsStepStart.put("name", "PWstep");
 page.evaluate("perfecto:report:stepStart", new Gson().toJson(paramsStepStart));
 //step end
 Map<String, Object> paramsStepEnd = new HashMap<>();
 paramsStepEnd.put("message", "PW step end");
 page.evaluate("perfecto:report:stepEnd", new Gson().toJson(paramsStepEnd));
- 
                                                            Add the testEndcode at the end of your test script, after all test steps are completed. This marks the end of the test and also allows you to specify:- 
                                                                    Whether the test run was successful or failed. In the following example, the successparameter is set tofalse, indicating that the test failed.
- 
                                                                    If the test run failed, a failure message to pass to the Perfecto report. You can use the failureDescriptionparameter to provide a detailed message explaining the reason for the failure.
 Copy//test stop
 Map<String, Object> paramsTestStop = new HashMap<>();
 paramsTestStop.put("success", false);
 paramsTestStop.put("failureDescription", "My failure message");
 
 page.evaluate("perfecto:report:testEnd", new Gson().toJson(paramsTestStop));
- 
                                                                    
 TypeScript
TypeScript
                                                Perform the following steps to add the PerfectoSmart Reporting code to your Playwright test scripts, placing the code snippets at appropriate points in your test flow.
- 
                                                            Add the testStartcode at the beginning of your test script, right after initializing the Playwright and browser context. This marks the start of the test.Copy//test start
 const paramsTestStart = {
 tags: ["tag1", "tag2"],
 name: "PWtestStart3",
 jobName: "My Job",
 jobNumber : "1",
 projectName:"project name",
 projectVersion: "1.0"
 };
 await page.evaluate("perfecto:report:testStart",JSON.stringify(paramsTestStart))
- 
                                                            Place the stepStartandstepEndcode around the specific steps you want to report. This marks the beginning and end of each step within your test.Copy//step start
 const paramsStepStart = {
 name: "step name"
 };
 await page.evaluate("perfecto:report:stepStart",JSON.stringify(paramsStepStart))
 //step end
 const paramsStepEnd = {
 message: "step end"
 };
 await page.evaluate("perfecto:report:stepEnd",JSON.stringify(paramsStepEnd))
- 
                                                            Add the testEndcode at the end of your test script, after all test steps are completed. This marks the end of the test and also allows you to specify:- 
                                                                    Whether the test run was successful or failed. In the following example, the successparameter is set tofalse, indicating that the test failed.
- 
                                                                    If the test run failed, a failure message to pass to the Perfecto report. You can use the failureDescriptionparameter to provide a detailed message explaining the reason for the failure.
 Copy//test end
 const paramsTestEnd = {
 success: false,
 failureDescription: "My failure message"
 };
 await page.evaluate("perfecto:report:testEnd",JSON.stringify(paramsTestEnd))
- 
                                                                    
 JavaScript
JavaScript
                                                Perform the following steps to add the PerfectoSmart Reporting code to your Playwright test scripts, placing the code snippets at appropriate points in your test flow.
- 
                                                            Add the paramsTestStartcode at the beginning of your test script, right after initializing the Playwright and browser context. This marks the start of the test.Copyconst paramsTestStart = {
 tags: ['Playwright', 'standalone'],
 name: 'Perfecto Playwright Test',
 jobName: 'My Job',
 jobNumber: '1',
 projectName: 'My Project',
 projectVersion: '1.0'
 };
 await page.evaluate('perfecto:report:testStart', JSON.stringify(paramsTestStart));
- 
                                                            Optionally, wrap specific steps with paramsStepStartandparamsStepEndto mark them in the report.Copy// Step start
 const paramsStepStart = { name: 'Navigate to Perfecto' };
 await page.evaluate('perfecto:report:stepStart', JSON.stringify(paramsStepStart));
 // ... your test step here ...
 // Step end
 const paramsStepEnd = { message: 'Navigation complete' };
 await page.evaluate('perfecto:report:stepEnd', JSON.stringify(paramsStepEnd));
- 
                                                            Add the paramsTestEndcode at the end of your test script, after all test steps are completed. This marks the end of the test and allows you to specify whether it passed or failed.Copyconst paramsTestEnd = {
 success: true // or false
 };
 await page.evaluate('perfecto:report:testEnd', JSON.stringify(paramsTestEnd));If the test fails, you can include a failure message: Copyconst paramsTestEnd = {
 success: false,
 failureDescription: 'Expected link not found'
 };
 await page.evaluate('perfecto:report:testEnd', JSON.stringify(paramsTestEnd));