feat: scaffolding

This commit is contained in:
2026-02-03 12:55:49 -08:00
parent c8a82646f8
commit 8f3aeb9391
12 changed files with 190 additions and 111 deletions
+14 -6
View File
@@ -1,13 +1,21 @@
import { getGreeting } from '../support/app.po';
/**
* @copyright 2026 NHCarrigan
* @copyright 2026 NHCarrigan
* @license Naomi's Public License
*/
describe('frontend-e2e', () => {
beforeEach(() => cy.visit('/'));
import { getGreeting } from "../support/app.po";
it('should display welcome message', () => {
describe("frontend-e2e", () => {
beforeEach(() => {
cy.visit("/");
});
it("should display welcome message", () => {
// Custom command example, see `../support/commands.ts` file
cy.login('my-email@something.com', 'myPassword');
cy.login("my-email@something.com", "myPassword");
// Function helper example, see `../support/app.po.ts` file
getGreeting().contains(/Welcome/);
});
});
});
+7 -1
View File
@@ -1 +1,7 @@
export const getGreeting = () => cy.get('h1');
/**
* @copyright 2026 NHCarrigan
* @copyright 2026 NHCarrigan
* @license Naomi's Public License
*/
export const getGreeting = (): Cypress.Chainable => cy.get("h1");
+25 -20
View File
@@ -1,35 +1,40 @@
/**
* @copyright 2026 NHCarrigan
* @copyright 2026 NHCarrigan
* @license Naomi's Public License
*/
/// <reference types="cypress" />
// ***********************************************
// This example commands.ts shows you how to
// create various custom commands and overwrite
// existing commands.
//
// For more comprehensive examples of custom
// commands please read more here:
// https://on.cypress.io/custom-commands
// ***********************************************
/**
* This example commands.ts shows you how to
* create various custom commands and overwrite
* existing commands.
*
* For more comprehensive examples of custom
* commands please read more here:
* https://on.cypress.io/custom-commands
*/
// eslint-disable-next-line @typescript-eslint/no-namespace
// eslint-disable-next-line @typescript-eslint/no-namespace -- Required for Cypress type extensions
declare namespace Cypress {
// eslint-disable-next-line @typescript-eslint/no-unused-vars
// eslint-disable-next-line @typescript-eslint/no-unused-vars -- Subject is required for type definition
interface Chainable<Subject> {
login(email: string, password: string): void;
login: (email: string, password: string) => void;
}
}
// -- This is a parent command --
Cypress.Commands.add('login', (email, password) => {
console.log('Custom command example: Login', email, password);
Cypress.Commands.add("login", (email, password) => {
// eslint-disable-next-line no-console -- Example command for demonstration
console.log("Custom command example: Login", email, password);
});
//
// -- This is a child command --
// Cypress.Commands.add("drag", { prevSubject: 'element'}, (subject, options) => { ... })
//
//
// -- This is a dual command --
// Cypress.Commands.add("dismiss", { prevSubject: 'optional'}, (subject, options) => { ... })
//
//
// -- This will overwrite an existing command --
// Cypress.Commands.overwrite("visit", (originalFn, url, options) => { ... })
// Cypress.Commands.overwrite("visit", (originalFn, url, options) => { ... })
+22 -15
View File
@@ -1,17 +1,24 @@
// ***********************************************************
// This example support/e2e.ts is processed and
// loaded automatically before your test files.
//
// This is a great place to put global configuration and
// behavior that modifies Cypress.
//
// You can change the location of this file or turn off
// automatically serving support files with the
// 'supportFile' configuration option.
//
// You can read more here:
// https://on.cypress.io/configuration
// ***********************************************************
/**
* @copyright 2026 NHCarrigan
* @license Naomi's Public License
* @author Naomi Carrigan
*/
/**
* This example support/e2e.ts is processed and
* loaded automatically before your test files.
*
* This is a great place to put global configuration and
* behavior that modifies Cypress.
*
* You can change the location of this file or turn off
* automatically serving support files with the
* 'supportFile' configuration option.
*
* You can read more here:
* https://on.cypress.io/configuration
*/
// Import commands.ts using ES2015 syntax:
import './commands';
// eslint-disable-next-line import/no-unassigned-import -- Side effects import for Cypress commands
import "./commands.ts";