Базовая аутентификация не сохраняется в StorageState

Я настраиваю проект драматурга и пытаюсь сохранить базовую аутентификацию для повторного использования в своих тестах с использованием зависимостей. Настройка всегда проходит успешно, но пример спецификации завершается с ошибкой 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()) и несколько разных вариантов, но ничего не работает. Что я делаю не так?

То, что вы устанавливаете в глобальной настройке, не является базовой HTTP-аутентификацией.

hardkoded 10.05.2024 14:25
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
В настоящее время производительность загрузки веб-сайта имеет решающее значение не только для удобства пользователей, но и для ранжирования в...
Безумие обратных вызовов в javascript [JS]
Безумие обратных вызовов в javascript [JS]
Здравствуйте! Юный падаван 🚀. Присоединяйся ко мне, чтобы разобраться в одной из самых запутанных концепций, когда вы начинаете изучать мир...
Система управления парковками с использованием HTML, CSS и JavaScript
Система управления парковками с использованием HTML, CSS и JavaScript
Веб-сайт по управлению парковками был создан с использованием HTML, CSS и JavaScript. Это простой сайт, ничего вычурного. Основная цель -...
JavaScript Вопросы с множественным выбором и ответы
JavaScript Вопросы с множественным выбором и ответы
Если вы ищете платформу, которая предоставляет вам бесплатный тест JavaScript MCQ (Multiple Choice Questions With Answers) для оценки ваших знаний,...
1
1
95
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Я считаю, что основные учетные данные аутентификации не хранятся в локальном хранилище или файлах 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 сеанса. Базовая аутентификация использует одни и те же учетные данные в каждом запросе, поэтому они просто кэшируются браузером в памяти.

Другие вопросы по теме

Как добавить базовую аутентификацию в конфигурацию Caddy с TLS и автоматическим продлением для обслуживания QuestDB через Docker
WKWebView или WebView: как выполнить базовую задачу аутентификации, аналогичную тому, как это делает Safari?
Этот сайт недоступен. Веб-страница express-basic-auth для swagger ui
Требуется базовая аутентификация, но тестовый пример проходит без аутентификации в приложении Spring boot
Можно ли избежать использования базовой аутентификации для подключаемого модуля безопасности AWS OpenSearch?
С момента обновления до RestSharp v110 всего 401 несанкционированная ошибка
Создание клиентского приложения Java для отображения потоковой передачи hls из внешнего источника с базовой аутентификацией
ОШИБКА Ошибка базовой аутентификации: несоответствие домена клиента для пользователя: [email protected] в WSO2 API Manager 4.1.0
Невозможно сделать HttpWebRequest, который работает с Postman
Как добавить дополнительные параметры запроса при повторной попытке wso2?