-
Notifications
You must be signed in to change notification settings - Fork 64
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
feat: ability to run tests in isolated environment #792
Conversation
6a49e98
to
1c0d736
Compare
README.md
Outdated
@@ -841,6 +841,7 @@ Option name | Description | |||
`key` | Cloud service access key or secret key. Default value is `null`. | |||
`region` | Ability to choose different datacenters for run in cloud service. Default value is `null`. | |||
`headless` | Ability to run headless browser in cloud service. Default value is `null`. | |||
`isolation` | Ability to execute tests in isolated clean-state environment ([incognito browser context](https://chromedevtools.github.io/devtools-protocol/tot/Target/#method-createBrowserContext)). Default value is `false`. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Возможно опцию правильнее назвать isolate
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
todo: выполнить doctoc
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Почему по умолчанию false, если мастер сейчас на бете восьмой версии? Давай сразу ещё один breaking change сделаем
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Хотел отдельным PR-ом переключить в hermione@8 с false
на true
, чтобы удобно чери пикнуть текущий коммит в hermione@7 и никому ничего не сломать. Но можно просто отдельный коммит сверху докинуть. Наверное так и сделаю.
return; | ||
} | ||
|
||
const { browserName, browserVersion = "", version = "" } = sessionCaps; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
В sessionCaps
хранится результат ответа браузера. Т.е. он содержит реальные версии браузеров.
version
использую в случае если пользователь запускает jsonwp браузер.
const incognitoCtx = await puppeteer.createIncognitoBrowserContext(); | ||
const page = await incognitoCtx.newPage(); | ||
|
||
if (automationProtocol === WEBDRIVER_PROTOCOL) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Переключение между окнами нужно только в webdriver
протоколе. В devtools с этим проблем нет.
|
||
if (automationProtocol === WEBDRIVER_PROTOCOL) { | ||
const windowIds = await this._session.getWindowHandles(); | ||
const incognitoWindowId = windowIds.find(id => id.includes(page.target()._targetId)); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Тут приходится использовать приватное свойство _targetId
. Очень странно, что оно не публичное. Мне оно нужно чтобы получить id нового открытого окна в который необходимо переключится. Изначально пытался переключаться в последнее окно из результата getWindowHandles
, но оказалось, что есть кейсы когда последнее окно не является только что созданным. Поэтому нашел только такой вариант.
Еще id
не матчатся один к одному. В webdriver они называются CDwindow_12345
, а в cdp просто 12345
. Issue про сделать данное поле публичным заведу в puppeteer и опишу свой кейс использования.
Версия wdio у нас четко зафиксирована поэтому кейсов когда это может сломаться на данный момент нет.
|
||
for (const ctx of browserCtxs) { | ||
if (ctx.isIncognito()) { | ||
await ctx.close(); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Инкогнито контексты можно сразу закрывать без необходимости явно закрывать все страницы.
} | ||
|
||
for (const page of await ctx.pages()) { | ||
await page.close(); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Не инкогнито контексты закрыть невозможно. В данном случае не инкогнито контекстом является дефолтный контекст, который запускается при запуске браузера. Его закрыть нельзя, можно закрыть только страницы.
@@ -390,6 +398,156 @@ describe("ExistingBrowser", () => { | |||
}); | |||
}); | |||
|
|||
describe("perform isolation", () => { | |||
let cdp, incognitoBrowserCtx, incognitoPage, incognitoTarget; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Не очень люблю создавать сущности в beforeEach
, но иначе некоторые тесты получались довольно жирные.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
В текущей реализации пользователю нужно в и так не маленькой документации изучать, что это за опция, как оно себя будет вести с testsPerSession: 1
и infinity
.
Что не нравится:
isolation
по умолчаниюfalse
. Почему бы не включить изначально, если вливаем в бету?- присутствие такой опции в принципе. Опять же, если можно по умолчанию ее включить и нет смысла ее выключать, то выглядит как лишняя
testsPerSession
ты указываешь, что при использовании изоляции можно поставить в infinity. А какие есть причины так не делать? Кажется, что никаких, и этотtestsPerSession
можно под капотом в нужных браузерах ставить вInfinity
По итогу получится, что с 8 версии Гермионы оно работает как нужно из коробки. Пользователей может смутить различие в :visited
, но тут предлагаю в testsPerSession
просто указать, что в новых хромах этот параметр игнорируются. Так сферический пользователь в вакууме, у которого возникнут вопросы по цвету посещённых ссылок, сможет прочитать ответ в документации, вместо того, чтобы самому разбираться в этих параметрах и браузерных контекстах в целом. Не-сферический пользователь не-в-вакууме просто оставит конфиги по умолчанию и не будет пользоваться такой классной штукой.
README.md
Outdated
@@ -841,6 +841,7 @@ Option name | Description | |||
`key` | Cloud service access key or secret key. Default value is `null`. | |||
`region` | Ability to choose different datacenters for run in cloud service. Default value is `null`. | |||
`headless` | Ability to run headless browser in cloud service. Default value is `null`. | |||
`isolation` | Ability to execute tests in isolated clean-state environment ([incognito browser context](https://chromedevtools.github.io/devtools-protocol/tot/Target/#method-createBrowserContext)). Default value is `false`. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Почему по умолчанию false, если мастер сейчас на бете восьмой версии? Давай сразу ещё один breaking change сделаем
assert.notCalled(logger.warn); | ||
}); | ||
|
||
it("test wasn't run in chrome", async () => { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
А как насчёт других браузеров, поддерживающих cdp? Типа Firefox/webkit
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Так как коммент оставлен к тесту, то не вижу необходимости проверять другие варианты browserName
.
Если вопрос был в целом, то webkit вообще не поддерживает CDP. А firefox имеет поддержку только в nightly сборке. Поэтому их поддерживать не стал.
Забыл написать, что хотел отдельный PR в hermione@8 оформить (хотел коммит черипикнуть в hermione@7). Но докину просто дополнительный коммит с переключением в
Пользователь может осознанно хотеть запускать зависимые тесты и чтобы состояние браузера не чистилось. Из-за этого я даже пилил такой плагин - https://github.com/gemini-testing/hermione-sequential-tests-run. Поэтому опцию я бы не стал удалять.
Для hermione@8 можно в этом кейсе только дефолт поменять в случае если изоляция не выключена и версия браузера удовлетворяет условию. Но если пользователь явно укажет |
BREAKING CHANGE: - tests in chrome@93 and higher now run in as isolated environment by default
1c0d736
to
473e96a
Compare
What's done?
Why?
testsPerSession: 1