Skip to content
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

e2e playwright test #54

Merged
merged 42 commits into from
Sep 11, 2023
Merged
Show file tree
Hide file tree
Changes from 21 commits
Commits
Show all changes
42 commits
Select commit Hold shift + click to select a range
f36fbca
nix version tests
divinenaman Aug 24, 2023
33204f7
flake checks
divinenaman Aug 24, 2023
f62e9df
Merge remote-tracking branch 'upstream/main' into test-thirtyfour
divinenaman Aug 24, 2023
437f543
merge
divinenaman Aug 24, 2023
97b35f8
Merge remote-tracking branch 'o/main' into test-thirtyfour
srid Aug 25, 2023
47f3874
handle tls error in tests
srid Aug 25, 2023
17ae376
test ignore
divinenaman Aug 25, 2023
15b2ff6
Merge remote-tracking branch 'upstream/main' into test-thirtyfour
divinenaman Aug 25, 2023
d8d716e
fmt
divinenaman Aug 25, 2023
af871a1
e2e nix module
divinenaman Aug 30, 2023
b11393b
working e2e nix module
divinenaman Aug 30, 2023
27600e0
fix flake formatting
Aug 31, 2023
d92eb90
wip: playwright flake module
divinenaman Aug 31, 2023
a3a1b8e
Merge branch 'test-thirtyfour' of github.com:divinenaman/nix-browser …
divinenaman Aug 31, 2023
9bd4b34
wip: playwright flake fix
divinenaman Aug 31, 2023
2741fa7
add playwright test
divinenaman Sep 1, 2023
234e6bd
Merge remote-tracking branch 'upstream/main' into test-thirtyfour
divinenaman Sep 2, 2023
4b3a30d
fixes
divinenaman Sep 3, 2023
9cfc8d5
add playwright test
Sep 4, 2023
d751512
fmt
Sep 4, 2023
ffce24b
review changes
Sep 5, 2023
2786d17
Merge remote-tracking branch 'upstream/main' into e2e-playwright
Sep 6, 2023
074a4bc
remove imports
Sep 7, 2023
d54c2f8
readme
Sep 7, 2023
ecebd62
vscode: add playwright extension
srid Sep 8, 2023
c8e6407
revert lock changes
Sep 8, 2023
44f5a30
Add github actions CI to run e2e tests
srid Sep 11, 2023
7986fcc
add playwright browser path
Sep 11, 2023
0a679ab
make vscode integration work
srid Sep 11, 2023
4dc81b9
avoid unnecessary rebuilds
srid Sep 11, 2023
efd89ef
.ts
srid Sep 11, 2023
905acf4
reindent
srid Sep 11, 2023
76bc79c
devDependencies is fine
srid Sep 11, 2023
a936003
simplify node_module management
srid Sep 11, 2023
6c6d13e
fix
srid Sep 11, 2023
6d42924
rename
srid Sep 11, 2023
fd754c7
not needed
srid Sep 11, 2023
eefb7aa
redundant
srid Sep 11, 2023
3c5650a
readme
srid Sep 11, 2023
4d5fc70
lock file is not needed
srid Sep 11, 2023
a452d36
No need for package.json either
srid Sep 11, 2023
f2aae2c
Merge remote-tracking branch 'origin/main' into e2e-playwright
srid Sep 11, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
121 changes: 66 additions & 55 deletions Cargo.lock
srid marked this conversation as resolved.
Show resolved Hide resolved

Large diffs are not rendered by default.

4 changes: 4 additions & 0 deletions e2e-playwright/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
node_modules/
/test-results/
/playwright-report/
/playwright/.cache/
41 changes: 41 additions & 0 deletions e2e-playwright/flake-module.nix
Original file line number Diff line number Diff line change
@@ -0,0 +1,41 @@
{ self, lib, inputs, ... }:
{
perSystem = { config, self', pkgs, system, ... }:
{
# e2e test service using playwright
process-compose.e2e-playwright-test =
let
TEST_PORT = "5000";
in
{
tui = false;
port = 8975;
settings.processes = {
start-app = {
command = "${lib.getExe self'.packages.default} --site-addr=127.0.0.1:${TEST_PORT} --no-open";
readiness_probe = {
exec.command = "${lib.getExe pkgs.curl} --fail 127.0.0.1:${TEST_PORT}";
initial_delay_seconds = 2;
period_seconds = 10;
timeout_seconds = 4;
};
};
test = {
environment = {
inherit TEST_PORT;
};
command = pkgs.writeShellApplication {
name = "e2e-playwright";
runtimeInputs = with pkgs; [ nodejs playwright-test ];
text = ''
cd e2e-playwright
playwright test --project chromium
'';
};
depends_on."start-app".condition = "process_healthy";
availability.exit_on_end = true;
};
};
};
};
}
69 changes: 69 additions & 0 deletions e2e-playwright/playwright.config.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,69 @@
// @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: 'line',
/* 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: `http://127.0.0.1:${process.env.TEST_PORT}`,

/* 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: 'chromium',
use: { ...devices['Desktop Chrome'] },
}

/* Test against mobile viewports. */
// {
// name: 'Mobile Chrome',
// use: { ...devices['Pixel 5'] },
// },
// {
// name: 'Mobile Safari',
// use: { ...devices['iPhone 12'] },
// },

/* Test against branded browsers. */
// {
// name: 'Microsoft Edge',
// use: { ...devices['Desktop Edge'], channel: 'msedge' },
// },
// {
// name: 'Google Chrome',
// use: { ...devices['Desktop Chrome'], channel: 'chrome' },
// },
],

/* Run your local dev server before starting the tests */
// webServer: {
// command: 'npm run start',
// url: 'http://127.0.0.1:3000',
// reuseExistingServer: !process.env.CI,
// },
});

8 changes: 8 additions & 0 deletions e2e-playwright/tests/nix-version.test.js
srid marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
// @ts-check
const { test, expect } = require('@playwright/test');

test('check nix version', async ({ page, request }) => {
await page.goto('/info');
const nixVersion = await page.locator(":text('Nix Version') + div").textContent();
await expect(nixVersion).toBeTruthy();
});
6 changes: 4 additions & 2 deletions flake.nix
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@
inputs.process-compose-flake.flakeModule
inputs.cargo-doc-live.flakeModule
(inputs.leptos-fullstack + /nix/flake-module.nix)
./e2e-playwright/flake-module.nix
];
perSystem = { config, self', pkgs, lib, system, ... }: {
_module.args.pkgs = import inputs.nixpkgs {
Expand All @@ -46,6 +47,7 @@
};

leptos-fullstack.overrideCraneArgs = oa: {
SSL_CERT_FILE = "${pkgs.cacert}/etc/ssl/certs/ca-bundle.crt";
nativeBuildInputs = (oa.nativeBuildInputs or [ ]) ++ [
pkgs.nix # cargo tests need nix
];
Expand All @@ -57,7 +59,7 @@

packages.default = self'.packages.nix-browser;

devShells.default = pkgs.mkShell {
devShells.default = pkgs.mkShell ({
inputsFrom = [
config.treefmt.build.devShell
self'.devShells.nix-browser
Expand All @@ -74,7 +76,7 @@
echo "🍎🍎 Run 'just <recipe>' to get started"
just
'';
};
});
};
};
}
6 changes: 5 additions & 1 deletion justfile
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,11 @@ alias w := watch

# Run tests (backend & frontend)
test:
cargo watch -- cargo leptos test
cargo-test
srid marked this conversation as resolved.
Show resolved Hide resolved

# Run tests (e2e-playwright)
e2e-playwright-test:
nix run .#e2e-playwright-test

# Run docs server (live reloading)
doc:
Expand Down
6 changes: 5 additions & 1 deletion src/server.rs
srid marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,11 @@ use crate::app::App;
use axum::response::Response as AxumResponse;
use axum::routing::IntoMakeService;
use axum::{body::Body, http::Request, response::IntoResponse};
use axum::{routing::post, Router};
use axum::{
http::StatusCode,
routing::{get, post},
Router,
};
srid marked this conversation as resolved.
Show resolved Hide resolved
use hyper::server::conn::AddrIncoming;
use leptos::*;
use leptos_axum::{generate_route_list, LeptosRoutes};
Expand Down