Я настраиваю проект драматурга и пытаюсь сохранить базовую аутентификацию для повторного использования в своих тестах с использованием зависимостей.
Настройка всегда проходит успешно, но пример спецификации завершается с ошибкой page.goto: net::ERR_INVALID_AUTH_CREDENTIALS at https://the-internet.herokuapp.com/basic_auth
Мой конфигурационный файл:
// @ts-check
const {defineConfig, devices} = require('@playwright/test');
/**
* Read environment variables from file.
* https://github.com/motdotla/dotenv
*/
// require('dotenv').config();
/**
* @see https://playwright.dev/docs/test-configuration
*/
module.exports = defineConfig({
testDir: './tests',
/* Run tests in files in parallel */
fullyParallel: true,
/* Fail the build on CI if you accidentally left test.only in the source code. */
forbidOnly: !!process.env.CI,
/* Retry on CI only */
retries: process.env.CI ? 2 : 0,
/* Opt out of parallel tests on CI. */
workers: process.env.CI ? 1 : undefined,
/* Reporter to use. See https://playwright.dev/docs/test-reporters */
reporter: 'html',
/* Shared settings for all the projects below. See https://playwright.dev/docs/api/class-testoptions. */
use: {
/* Base URL to use in actions like `await page.goto('/')`. */
baseURL: 'https://the-internet.herokuapp.com/basic_auth',
/* Collect trace when retrying the failed test. See https://playwright.dev/docs/trace-viewer */
trace: 'on-first-retry',
},
/* Configure projects for major browsers */
projects: [
{
name: 'setup',
testDir: './',
testMatch: 'globalSetup.js'
},
{
name: 'testrun',
dependencies: ['setup'],
use: { storageState: './LoginAuth.json' }
},
],
}
globalSetup:
test('setup', async ({ page }) => {
const authHeaders = 'Basic ' + Buffer.from('admin:admin').toString('base64');
await page.setExtraHTTPHeaders({ Authorization : authHeaders })
await page.goto('');
await expect(page.getByText('Congratulations!')).toBeVisible();
await page.context().storageState({ path: './LoginAuth.json' })
})
my spec:
test('new fckn test', async ({page}) => {
await page.goto('');
await expect(page.getByText('Congratulations!')).toBeVisible();
})
Я уже пробовал старый способ (функция globalSetup()) и несколько разных вариантов, но ничего не работает. Что я делаю не так?



![Безумие обратных вызовов в javascript [JS]](https://i.imgur.com/WsjO6zJb.png)


Я считаю, что основные учетные данные аутентификации не хранятся в локальном хранилище или файлах cookie.
Вы можете установить httpCredentials в конфигурации и удалить проект установки. Пример:
import { defineConfig } from '@playwright/test';
export default defineConfig({
use: {
httpCredentials: {
username: 'user',
password: 'pass',
},
},
});
Документы: https://playwright.dev/docs/api/class-testoptions#test-options-http-credentials
Принятый вами подход действителен для случаев, когда используются файлы cookie сеанса. Базовая аутентификация использует одни и те же учетные данные в каждом запросе, поэтому они просто кэшируются браузером в памяти.
То, что вы устанавливаете в глобальной настройке, не является базовой HTTP-аутентификацией.