Playwright Demo - This project is based on Microsoft Playwright which enables reliable end-to-end testing for modern web apps.
Top Features:
- Easy to Configure.
- Auto-waits for all the relevant checks to pass and only then performs the requested action.
- Records videos for Test Cases.
- Records the test script and every action on the target page is turned into generated script.
- Generates trace file, which gives in-depth details of Test Case execution.
- Execution of test case is faster when compared with other competitive framework in market.
- Supports Headful/Headless mode execution for Firefox/Webkit/Google Chrome/Chromium/MS Edge on Windows/Linux/Mac machines.
- It supports API testing (From Playwright version 1.16 onwards)
- It can be used to simulate browser behaviour on mobile devices, and supports over 100+ devices.
- It has ability to produce and visually compare screenshots.
- To slow down execution slowMo option is available.
- Supports 'download' event monitoring, so there is no need for user to actually wait for downloads to finish.
- Supports Serial and Parallel execution.
- Allure/HTML Reports are generated after execution with an option to capture screenshot/video/trace file on failure.
- Nonetheless Support from Microsoft so FREQUENT RELEASES and turn arounf time for any queries is 48 hours.
Bonus:
- Supports PostgresSQL using 'pg' module.
- Supports Excel File Read/Write using 'excel-js' module.
- Converts HTL Reports to Zip format which can shared across.
The following software are required:
- nodejs : Download and Install Node JS from https://nodejs.org/en/download/ 
- Install Java 8 or above, Allure Reports require Java 8 or higher.
- Install Java 11 instead of Java 8 if you intend to use Sonar Qube.
- allure commandline : Install allure command line for generating Allure Reports using npm ci -g allure-commandline 
- If you wish to include SonarQube follow the below steps: - Install Java 11 and add java path to "PATH" environment variable.
- Download SonarQube community server from the below url and unzip it to desired location.
 https://www.sonarqube.org/downloads/ - Download Sonar Scanner for your desired OS (Windows in my case) from below location and unzip it to desired location. Then navigate to bin location once unzipped and provide the path to "PATH" environment variable.
 https://docs.sonarqube.org/latest/analysis/scan/sonarscanner/ 
- Clone the repo using below URL
https://github.com/akshayp7/playwright-typescipt-playwright-test.git- Navigate to folder and install npm packages using:
npm ci- For Browser Configuration, change required parameters in playwright.config.ts.
- For execution entire test suite on all available browsers simultaneously execute below command where "ENV" can be "qa" or "dev", Test Cases are present in "tests" folder:
npx cross-env ENV=qa npm run test- For executing single test case on Chrome browser execute the below command, you can change the browser for execution e.g. if you want to run test cases on Firefox, you can change --project=Firefoxagainsttest:singleinpackage.json, just make sure the browser name given matches the name given inplaywright.config.ts.
npx cross-env ENV=qa npm run test:single- For executing test cases in parallel, provide a suitable tag @SmokeTestat the start of your test case name, then inpackage.jsonagainsttest:parallelgive the tag value and execute :
npx cross-env ENV=qa npm run test:parallel- For executing test cases in sequence, provide a suitable tag @SmokeTestat the start of your test case name, then inpackage.jsonagainsttest:serialgive the tag value and execute,workersparameter correspond to test cases you want to execute simultaneously e.g.--workers=3, executes 3 test cases simultaneously :
npx cross-env ENV=qa npm run test:serial- For executing API test cases, please provide "ENV" value as "qaApi" or "devApi" :
npx cross-env ENV=qaApi npm run test:api- For recording test scripts :
npm run test:record- To produce and visually compare screenshots execute below command. On first execution reference screenshot will be generated for comparision with subsequent runs.
npx cross-env ENV=qa npm run test:visual- For emulating test cases on any device, in playwright.config.ts, under device section provide desired device name and execute :
npx cross-env ENV=qa npm run test:device- For Allure Report generation execute :
npm run allureReport- For HTML Report generation execute below command , single static HTML report(index.html) which can be sent via email is generated in "html-report" folder:
- For converting HTML Reports to zip file "adm-zip" library is used, the logic is implemented in global-teardown.ts, to make sure this runs after all the test are executed and after reports are generated,global-teardown.tsis given as a parameter for "globalTeardown" inplaywright.config.tsfile. Results are generated ashtml-report.zipin project directory.
- For debugging test cases add debug points, the press CNTRL+SHIFT+P and type "debug:debug npm script", on the edit box select desired script.
- Screenshots, Videos and Trace files will be generated in test-results folder.
- To change your username go to testConfig.tsand provide value againstusername
- To change password, go to lib/WebActionsindecipherPassword()uncommentENCRYPTcode block and replacepasswordwith your password, execute the test case, Encrypted password will be printed on your console . Copy Encrypted password intestConfig.tsagainstpasswordfield. You can comment Encrypt bloack ater this.
- For executing Postgres DB test case, navigate to testConfig.tsand provide values fordbUsername, dbPassword, dbServerName, dbPort, dbName. Refer totests/DB.test.tsfor connecting to DB and Firing a Query.
- For viewing trace files, go to folder where trace.zipis generated and execute :
npx playwright show-trace trace.zip- You can change the Logging Message at Test Case/Test Step Level in CustomReporterConfig.ts file
- In tsconfig.jsonfile inpathssection we can re-assign the long path imports like '../../' to a variable which starts with '@' and then we can use it to shorten our import statements in respective file. In the below example wherever '../../pageFactory/pageRepository/' import statement is used we can replace it with '@pages'
"@pages/*":["pageFactory/pageRepository/*"]Once you have completed setup for SonarQube given in Prerequisites section, configure SonarQube as given below
- Go to the path where sonarqube server(For e.g. : C:\SonarQube\sonarqube-9.1.0.47736) is unzipped -> Go to conf Folder -> open sonar.properties file and add the below prperties and save the file, you can give any port you wish I have used port 9000.
sonar.host.url=http://localhost:9000 sonar.sourceEncoding=UTF-8- Go to the path where sonarqube server(For e.g. : C:\SonarQube\sonarqube-9.1.0.47736) is unzipped -> Go to bin section -> Go to the folder as per the OS you are using , in my case windows-x86-64 -> Double click on Start Sonar and wait for it to display SonarQube is up (you might encounter some java errors but its fine don't close the terminal).
- Go to the browser and naigate to http://localhost:9000 , default username is admin, default password isadmin. It might ask you to provide a new password for if you have logged in for first time, I have changed default password topassword.
- In your working project (playwright-typescipt-playwright-test), navigate to sonar-project.propertiesfile and provide the credentials configured on server webpage username value insonar.loginand password insonar.password, in my case username isadminand password was changed topassword.
sonar.login=admin sonar.password=password-  You can provide any project name in sonar.projectKey.
-  Specify a version in sonar.projectVersion.
-  Provide UTF-8insonar.sourceEncoding.
-  In sonar.languageprovide the language you want to run scan on (For e.g. for typescipt its ts and for javascript its js).
-  If you have eslint file in your project provide the location in sonar.eslint.eslintconfigpath.
-  You can exclude file from scanning like node_modules, results , Downloads section in sonar.exclusions.
-  You can give your project location in sonar.sourcessection I have provided it as./because mysonar-project.propertiesfile is within my project. If your properties files is somewhere else you have to provide the complete project path.
-  Now go to the location where sonar-project.propertiesis present and runsonar-scannercommand (In my case I will diectly run it inside my project), and wait for scan to get over with success message.
-  Now navigate to http://localhost:9000/and click on your project key displayed and go to Issues section, you can find all the suggestions and issues here. You can fix the issues ans rerunsonar-scannercommand once again.
-    For running the tests on Docker container we have to first build a image from Dockerfile and then run the image to spawn container on which the test scripts will run. 
-  For building image from Docker run below command, where path to Dockerfile must be provided after -f tag and name of the image must be provided after -t tag. 
docker build . -f Dockerfile -t playtest- Once the image is generated we can run the image to spawn container and run scrips using below command. In Below Command "playContainer" is name of the container created using "playtest" image.
docker run --name playContainer playtest- If you want to run a different test or provide custom command, Go to Dockerfile and edit the last line which is CMD section. The below sample runs test cases serially on QA environment. Once you have edited the CMD section we have to follow Step 1 to build a new image and ten run the Container from that image.
CMD ["npx","cross-env","ENV=qa","npm","run","test:serial"]