pierscowburn 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							5db7ce5964 
							
						 
					 
					
						
						
							
							fix: propagate exit code in experimental mode ( #12070 )  
						
						... 
						
						
						
						In experimental ESM mode a child process is forked in order to run the tests. Currently the exit code of this child process is not propagated to the exit code of the parent process, which means that the process exits with a status code of `0` even if some of the tests failed.
This makes it difficult to use Playwright in CI in experimental mode, as the CI pipeline as a whole will pass despite the test failures.
This change addresses this by propagating the exit code in the case where it is non-zero. 
						
						
					 
					
						2022-02-15 13:10:35 -08:00 
						 
				 
			
				
					
						
							
							
								Yury Semikhatsky 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							f15610b874 
							
						 
					 
					
						
						
							
							fix(fetch): always return non-empty body regardless of request method ( #12102 )  
						
						
						
						
					 
					
						2022-02-15 09:06:21 -08:00 
						 
				 
			
				
					
						
							
							
								Andrey Lushnikov 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							363b8a6970 
							
						 
					 
					
						
						
							
							feat: support mask option in screenshot methods ( #12072 )  
						
						... 
						
						
						
						Fixes https://github.com/microsoft/playwright/issues/10162  
						
						
					 
					
						2022-02-15 07:05:05 -08:00 
						 
				 
			
				
					
						
							
							
								Dmitry Gozman 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							5a0445b8da 
							
						 
					 
					
						
						
							
							feat(remote): let client enable/disable sock proxy ( #12086 )  
						
						
						
						
					 
					
						2022-02-14 15:10:58 -08:00 
						 
				 
			
				
					
						
							
							
								Andrey Lushnikov 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							ef21ce3f56 
							
						 
					 
					
						
						
							
							feat(test-runner): filter out syntax error stack traces ( #12095 )  
						
						... 
						
						
						
						Filter out long stack traces from babel when it fails compilation
due to syntax error in test. 
						
						
					 
					
						2022-02-14 14:33:14 -08:00 
						 
				 
			
				
					
						
							
							
								Dmitry Gozman 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							9814c592d2 
							
						 
					 
					
						
						
							
							fix(test runner): shutdown redundant workers ( #12062 )  
						
						
						
						
					 
					
						2022-02-14 10:57:15 -08:00 
						 
				 
			
				
					
						
							
							
								Dmitry Gozman 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							fb00991a78 
							
						 
					 
					
						
						
							
							chore: intercept socks proxy in the driver ( #12021 )  
						
						
						
						
					 
					
						2022-02-13 14:03:47 -08:00 
						 
				 
			
				
					
						
							
							
								Pavel Feldman 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							96b5831a49 
							
						 
					 
					
						
						
							
							chore: add support private methods in TS ( #12051 )  
						
						
						
						
					 
					
						2022-02-11 14:46:49 -08:00 
						 
				 
			
				
					
						
							
							
								Yury Semikhatsky 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							abd7084bcc 
							
						 
					 
					
						
						
							
							fix: match default font families in headless chromium ( #11340 )  
						
						
						
						
					 
					
						2022-02-11 09:06:17 -08:00 
						 
				 
			
				
					
						
							
							
								Dmitry Gozman 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							d8db785c0a 
							
						 
					 
					
						
						
							
							fix(reporters): correctly handle missing stdout.columns ( #12016 )  
						
						... 
						
						
						
						When columns are not available, do not trim the output. 
						
						
					 
					
						2022-02-11 08:33:56 -08:00 
						 
				 
			
				
					
						
							
							
								Dmitry Gozman 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							66b5cf5ae1 
							
						 
					 
					
						
						
							
							feat(remote): make PlaywrightServer work with browserType.connect ( #11849 )  
						
						... 
						
						
						
						This changes PlaywrigtServer to serve connections like `ws://localhost:3333/?browser=chromium`:
- launches the browser;
- talks `browserType.connect`-style protocol over websocket;
- compatible with `connectOptions` fixture.
```js
await playwright.chromium.connect({ wsEndpoint: 'ws://localhost:3333/?browser=chrome' });
``` 
						
						
					 
					
						2022-02-10 16:36:23 -08:00 
						 
				 
			
				
					
						
							
							
								Ross Wollman 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							0d42c16a17 
							
						 
					 
					
						
						
							
							fix(test-runner): undefined body crash with manual attachments ( #11995 )  
						
						... 
						
						
						
						The new (as of 1.18) `async testInfo.attach(…)` API handles this
gracefully (and is part of the reason for the new API's existence).
However, for the foreseeable future, it's still possible to manually
push onto the attachments array where we can't validate the contents
until it's too late, so this change ensures more graceful handling in
that case.
Fixes  #11565  
						
						
					 
					
						2022-02-10 12:33:38 -08:00 
						 
				 
			
				
					
						
							
							
								Dmitry Gozman 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							9a8e55493f 
							
						 
					 
					
						
						
							
							test: add a test for fetch api respecting port forwarding ( #12007 )  
						
						
						
						
					 
					
						2022-02-10 12:05:35 -08:00 
						 
				 
			
				
					
						
							
							
								Dmitry Gozman 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							9c66068971 
							
						 
					 
					
						
						
							
							fix(connect): make route.fulfill({ response }) work ( #12006 )  
						
						
						
						
					 
					
						2022-02-10 12:05:04 -08:00 
						 
				 
			
				
					
						
							
							
								Andrey Lushnikov 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							9287ef2dfb 
							
						 
					 
					
						
						
							
							test: skip test when run with PWTEST_TRACING ( #11999 )  
						
						... 
						
						
						
						This test tries to enable tracing itself; double-enabling
tracing throws an error.
This started failing after 284f76357f 
						
						
					 
					
						2022-02-10 09:45:18 -08:00 
						 
				 
			
				
					
						
							
							
								Pavel Feldman 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							fbc05b74a7 
							
						 
					 
					
						
						
							
							chore: revert "fix(test-runner): escape backslashes in win cli ( #11763 )" ( #12004 )  
						
						
						
						
					 
					
						2022-02-10 07:02:37 -08:00 
						 
				 
			
				
					
						
							
							
								Mateusz Burzyński 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							b0cd5b1420 
							
						 
					 
					
						
						
							
							feat(mouse): set .buttons correctly for basic mouse commands in Chrome ( #10698 )  
						
						... 
						
						
						
						Co-authored-by: Andrey Lushnikov <aslushnikov@gmail.com> 
						
						
					 
					
						2022-02-09 20:48:16 -08:00 
						 
				 
			
				
					
						
							
							
								Dmitry Gozman 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							284f76357f 
							
						 
					 
					
						
						
							
							test: unflake browsertype-connect.spec ( #11994 )  
						
						... 
						
						
						
						Consider the scenario:
- First test starts a remote server, connects to it and does not close.
- Remote server fixture stops the server in teardown. Meanwhile,
  the connected browser did not get notified about disconnect just yet.
- Second test starts and sets up tracing in the old connected browser.
- Tracing fails because the browser now realises it has disconnected. 
						
						
					 
					
						2022-02-09 17:00:33 -08:00 
						 
				 
			
				
					
						
							
							
								Andrey Lushnikov 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							6904b3294e 
							
						 
					 
					
						
						
							
							fix(test-runner): fix browser initialization in test modifiers ( #11984 )  
						
						... 
						
						
						
						Fixes  #11985  
					
						2022-02-09 15:30:14 -08:00 
						 
				 
			
				
					
						
							
							
								Dmitry Gozman 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							ae7c52154f 
							
						 
					 
					
						
						
							
							fix(fixtures): make sure connected browser respects context options ( #11990 )  
						
						... 
						
						
						
						Connected browser was wired up to the wrong browserType object. 
						
						
					 
					
						2022-02-09 15:25:15 -08:00 
						 
				 
			
				
					
						
							
							
								Andrey Lushnikov 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							6f87955243 
							
						 
					 
					
						
						
							
							feat: introduce disableAnimations option for screenshots ( #11870 )  
						
						... 
						
						
						
						This option stops all kinds of CSS animations while doing screenshot:
- CSS animations
- CSS transitions
- Web Animations
Animations get different treatment depending on animation duration:
- finite animations are fast-forwarded to its end, issuing the
  `transitionend` event.
- Infinite animations are resetted to its beginning, and then
  resumed after the screenshot.
References #9938 , fixes  #11912  
						
						
					 
					
						2022-02-09 12:52:11 -08:00 
						 
				 
			
				
					
						
							
							
								Darío Kondratiuk 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							48cc41f3e7 
							
						 
					 
					
						
						
							
							feat: add key support on react engine ( #11970 )  
						
						... 
						
						
						
						I've got [this question](https://stackoverflow.com/questions/71050193/react-locator-example/71052432#71052432 ) on StackOverflow. And although, in that case, the `key` was part of the `props` attributes. That might not always be true.
I am bringing this to the tell to see what you think about this.
I'm also fixing a typo :) 
						
						
					 
					
						2022-02-09 11:33:15 -08:00 
						 
				 
			
				
					
						
							
							
								Andrey Lushnikov 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							439c8e9c40 
							
						 
					 
					
						
						
							
							test: fix tests for chromium-based browser channels ( #11974 )  
						
						
						
						
					 
					
						2022-02-09 11:29:16 -08:00 
						 
				 
			
				
					
						
							
							
								Andrey Lushnikov 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							40b4218962 
							
						 
					 
					
						
						
							
							chore: roll stable test runner to Feb 9, 2022 ( #11971 )  
						
						
						
						
					 
					
						2022-02-09 09:34:25 -08:00 
						 
				 
			
				
					
						
							
							
								Yury Semikhatsky 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							706c897031 
							
						 
					 
					
						
						
							
							feat(fixtures): respect tracing config for APIRequestContext ( #11954 )  
						
						
						
						
					 
					
						2022-02-09 08:54:09 -08:00 
						 
				 
			
				
					
						
							
							
								Pavel Feldman 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							e9e5de2d57 
							
						 
					 
					
						
						
							
							feat(debug): allow preprocessing JS scripts as well ( #11953 )  
						
						
						
						
					 
					
						2022-02-09 07:14:11 -08:00 
						 
				 
			
				
					
						
							
							
								Dmitry Gozman 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							19368e93af 
							
						 
					 
					
						
						
							
							feat(test runner): support connectOptions ( #11919 )  
						
						... 
						
						
						
						This allows to specify `connectOptions` in the config that
switch built-in `browser` to be remotely connected. 
						
						
					 
					
						2022-02-08 20:45:42 -08:00 
						 
				 
			
				
					
						
							
							
								Dmitry Gozman 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							5881a46ecf 
							
						 
					 
					
						
						
							
							fix(test runner): skip beforeAll/afterAll when all tests are skipped ( #11952 )  
						
						... 
						
						
						
						There is a corner case where tests were skipped like this:
```js
test.skip('title', () => {});
``` 
						
						
					 
					
						2022-02-08 16:36:30 -08:00 
						 
				 
			
				
					
						
							
							
								Dmitry Gozman 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							e92caf01b3 
							
						 
					 
					
						
						
							
							fix(webServer): do not set baseURL equal to webServer.url ( #11951 )  
						
						
						
						
					 
					
						2022-02-08 15:57:36 -08:00 
						 
				 
			
				
					
						
							
							
								Pavel Feldman 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							8dff2e35c8 
							
						 
					 
					
						
						
							
							chore: don't throw on no testDir ( #11950 )  
						
						
						
						
					 
					
						2022-02-08 15:27:05 -08:00 
						 
				 
			
				
					
						
							
							
								Pavel Feldman 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							b2e15b8c60 
							
						 
					 
					
						
						
							
							chore: mute more test runner extension vars ( #11881 )  
						
						
						
						
					 
					
						2022-02-08 09:22:45 -08:00 
						 
				 
			
				
					
						
							
							
								Dmitry Gozman 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							8a5c93436d 
							
						 
					 
					
						
						
							
							fix(reporter): do not report parallel tests as slow ( #11921 )  
						
						
						
						
					 
					
						2022-02-07 20:10:13 -08:00 
						 
				 
			
				
					
						
							
							
								Yury Semikhatsky 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							1e00218ead 
							
						 
					 
					
						
						
							
							feat(tracing): suport loading multiple files in trace viewer ( #11880 )  
						
						
						
						
					 
					
						2022-02-07 17:05:42 -08:00 
						 
				 
			
				
					
						
							
							
								Dmitry Gozman 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							4ef22d3387 
							
						 
					 
					
						
						
							
							test: enable "should record open in a new tab with url" on webkit ( #11917 )  
						
						
						
						
					 
					
						2022-02-07 16:09:11 -08:00 
						 
				 
			
				
					
						
							
							
								Pavel Feldman 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							9116adc684 
							
						 
					 
					
						
						
							
							chore: allow opt-into the legacy global setup mode ( #11888 )  
						
						
						
						
					 
					
						2022-02-07 10:41:56 -08:00 
						 
				 
			
				
					
						
							
							
								Dmitry Gozman 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							f82e09be04 
							
						 
					 
					
						
						
							
							feat(codegen): generate locators and frame locators ( #11873 )  
						
						
						
						
					 
					
						2022-02-04 19:27:45 -08:00 
						 
				 
			
				
					
						
							
							
								Dmitry Gozman 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							1503264aca 
							
						 
					 
					
						
						
							
							test: decrease threshold for flaky "should play audio" ( #11878 )  
						
						
						
						
					 
					
						2022-02-04 16:14:48 -08:00 
						 
				 
			
				
					
						
							
							
								Dmitry Gozman 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							af4944388f 
							
						 
					 
					
						
						
							
							test: skip "should support has:locator" on tracing bots ( #11876 )  
						
						
						
						
					 
					
						2022-02-04 15:34:33 -08:00 
						 
				 
			
				
					
						
							
							
								Dmitry Gozman 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							c45dacc834 
							
						 
					 
					
						
						
							
							feat(codegen): make selector generator strict ( #11856 )  
						
						... 
						
						
						
						This is required to migrate to locators. 
						
						
					 
					
						2022-02-04 07:34:23 -08:00 
						 
				 
			
				
					
						
							
							
								Andrey Lushnikov 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							547a32885b 
							
						 
					 
					
						
						
							
							feat: hide blinking cursor when making screenshots ( #11854 )  
						
						... 
						
						
						
						References #9938  
						
						
					 
					
						2022-02-03 21:44:23 -08:00 
						 
				 
			
				
					
						
							
							
								Dmitry Gozman 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							c9e99d5d97 
							
						 
					 
					
						
						
							
							test: reenable "should intercept network activity from worker 2" ( #11851 )  
						
						
						
						
					 
					
						2022-02-03 17:16:40 -08:00 
						 
				 
			
				
					
						
							
							
								Dmitry Gozman 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							d9a8bb057d 
							
						 
					 
					
						
						
							
							fix(test-fail): allow unhandled expects in test.fail ( #11850 )  
						
						... 
						
						
						
						Previously, we would consider this a worker error, but
we make an exception for "expect()" calls. 
						
						
					 
					
						2022-02-03 17:14:12 -08:00 
						 
				 
			
				
					
						
							
							
								Yury Semikhatsky 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							d237ad76c1 
							
						 
					 
					
						
						
							
							test: mark cltr+click test as timing out on windows ( #11840 )  
						
						
						
						
					 
					
						2022-02-03 09:09:38 -08:00 
						 
				 
			
				
					
						
							
							
								Pavel Feldman 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							fdda759a9d 
							
						 
					 
					
						
						
							
							feat(parallel): allow setting enclosing scope parallel mode ( #11822 )  
						
						
						
						
					 
					
						2022-02-02 20:44:11 -08:00 
						 
				 
			
				
					
						
							
							
								Andrey Lushnikov 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							ba0c7e679b 
							
						 
					 
					
						
						
							
							feat(test-runner): support expect.soft ( #11800 )  
						
						... 
						
						
						
						Soft expects will still fail the test, but will not abort it's execution. As a consequence of this:
-  `TestResult` now might have multiple errors, which is reflected with a new `testResult.erros: TestError[]` field.
- `TestInfo` now might have multiple errors as well, which is reflected with a new `testInfo.errors: TestError[]` field.
Fixes  #7819  
						
						
					 
					
						2022-02-02 18:33:51 -08:00 
						 
				 
			
				
					
						
							
							
								Dmitry Gozman 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							f587a43932 
							
						 
					 
					
						
						
							
							feat(locator): "has" option ( #11411 )  
						
						... 
						
						
						
						This introduces `locator('div', { has: locator })` syntax that matches elements containing other elements.
Can be used together with `hasText`.
Internally, has selector engine takes an inner selector escaped with double-quotes:
`div >> has="li >> span >> text=Foo" >> span`. 
						
						
					 
					
						2022-02-02 16:55:50 -08:00 
						 
				 
			
				
					
						
							
							
								github-actions[bot] 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							fba523a9d0 
							
						 
					 
					
						
						
							
							feat(chromium): roll to r965416 ( #11802 )  
						
						... 
						
						
						
						Co-authored-by: github-actions <41898282+github-actions[bot]@users.noreply.github.com>
Co-authored-by: Max Schmitt <max@schmitt.mx> 
						
						
					 
					
						2022-02-02 11:39:10 +01:00 
						 
				 
			
				
					
						
							
							
								Max Schmitt 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							c752b28516 
							
						 
					 
					
						
						
							
							chore: pin production dependencies ( #11793 )  
						
						
						
						
					 
					
						2022-02-02 11:14:41 +01:00 
						 
				 
			
				
					
						
							
							
								Andrey Lushnikov 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							b0daa7754f 
							
						 
					 
					
						
						
							
							feat: filter stack traces to exclude test runner frames ( #11795 )  
						
						... 
						
						
						
						Before:
```bash
Running 1 test using 1 worker
  1) [chromium] › tests/example.spec.ts:3:1 › should work ==========================================
    Error: expect(received).toBe(expected) // Object.is equality
    Expected: 2
    Received: 1
      2 |
      3 | test('should work', async({page}) => {
    > 4 |   expect(1).toBe(2);
        |             ^
      5 | });
      6 |
        at Proxy.<anonymous> (/Users/andreylushnikov/prog/playwright/packages/playwright-test/src/expect.ts:151:30)
        at /Users/andreylushnikov/tmp/tests/example.spec.ts:4:13
        at /Users/andreylushnikov/prog/playwright/packages/playwright-test/src/workerRunner.ts:335:13
        at runNextTicks (node:internal/process/task_queues:61:5)
        at processImmediate (node:internal/timers:437:9)
        at TestInfoImpl._runFn (/Users/andreylushnikov/prog/playwright/packages/playwright-test/src/testInfo.ts:164:7)
        at WorkerRunner._runTestWithBeforeHooks (/Users/andreylushnikov/prog/playwright/packages/playwright-test/src/workerRunner.ts:317:24)
        at TimeoutRunner.run (/Users/andreylushnikov/prog/playwright/packages/playwright-core/src/utils/async.ts:48:14)
        at TestInfoImpl._runWithTimeout (/Users/andreylushnikov/prog/playwright/packages/playwright-test/src/testInfo.ts:151:7)
        at WorkerRunner._runTestOrAllHook (/Users/andreylushnikov/prog/playwright/packages/playwright-test/src/workerRunner.ts:276:5)
        at WorkerRunner._runSuite (/Users/andreylushnikov/prog/playwright/packages/playwright-test/src/workerRunner.ts:190:11)
        at WorkerRunner.run (/Users/andreylushnikov/prog/playwright/packages/playwright-test/src/workerRunner.ts:137:9)
        at process.<anonymous> (/Users/andreylushnikov/prog/playwright/packages/playwright-test/src/worker.ts:87:5)
```
after:
```
Running 1 test using 1 worker
  1) [chromium] › tests/example.spec.ts:3:1 › should work ==========================================
    Error: expect(received).toBe(expected) // Object.is equality
    Expected: 2
    Received: 1
      2 |
      3 | test('should work', async({page}) => {
    > 4 |   expect(1).toBe(2);
        |             ^
      5 | });
      6 |
        at /Users/andreylushnikov/tmp/tests/example.spec.ts:4:13
``` 
						
						
					 
					
						2022-02-01 18:40:44 -08:00 
						 
				 
			
				
					
						
							
							
								Dmitry Gozman 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							a30bc171c5 
							
						 
					 
					
						
						
							
							chore: make playwright-test tests debuggable with extension ( #11798 )  
						
						
						
						
					 
					
						2022-02-01 17:15:55 -08:00