Major infrastructure changes: - BaseUITestCase: per-suite app termination via class setUp() prevents stale state when parallel clones share simulators - relaunchBetweenTests override for suites that modify login/onboarding state - focusAndType: dedicated SecureTextField path handles iOS strong password autofill suggestions (Choose My Own Password / Not Now dialogs) - LoginScreenObject: tapSignUp/tapForgotPassword use scrollIntoView for offscreen buttons instead of simple swipeUp - Removed all coordinate taps from ForgotPasswordScreen, VerifyResetCodeScreen, ResetPasswordScreen (Rule 3 compliance) - Removed all usleep calls from screen objects (Rule 14 compliance) App fixes exposed by tests: - ContractorsListView: added onDismiss to sheet for list refresh after save - AllTasksView: added Task.RefreshButton accessibility identifier - AccessibilityIdentifiers: added Task.refreshButton - DocumentsWarrantiesView: onDismiss handler for document list refresh - Various form views: textContentType, submitLabel, onSubmit for keyboard flow Test fixes: - PasswordResetTests: handle auto-login after reset (app skips success screen) - AuthenticatedUITestCase: refreshTasks() helper for kanban toolbar button - All pre-login suites use relaunchBetweenTests for test independence - Deleted dead code: AuthenticatedTestCase, SeededTestData, SeedTests, CleanupTests, old Suite0/2/3, Suite1_RegistrationRebuildTests 10 remaining failures: 5 iOS strong password autofill (simulator env), 3 pull-to-refresh gesture on empty lists, 2 feature coverage edge cases. Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
51 lines
2.0 KiB
Swift
51 lines
2.0 KiB
Swift
import XCTest
|
|
|
|
/// Simple test to verify basic app launch and login screen
|
|
/// This is the foundation test - if this works, we can build more complex tests
|
|
final class SimpleLoginTest: BaseUITestCase {
|
|
override var includeResetStateLaunchArgument: Bool { false }
|
|
|
|
|
|
override func setUpWithError() throws {
|
|
try super.setUpWithError()
|
|
|
|
// CRITICAL: Ensure we're logged out before each test
|
|
ensureLoggedOut()
|
|
}
|
|
|
|
override func tearDownWithError() throws {
|
|
try super.tearDownWithError()
|
|
}
|
|
|
|
// MARK: - Helper Methods
|
|
|
|
/// Ensures the user is logged out and on the login screen
|
|
private func ensureLoggedOut() {
|
|
UITestHelpers.ensureLoggedOut(app: app)
|
|
}
|
|
|
|
// MARK: - Tests
|
|
|
|
/// Test 1: App launches and shows login screen (or logs out if needed)
|
|
func testAppLaunchesAndShowsLoginScreen() {
|
|
let usernameField = app.textFields[AccessibilityIdentifiers.Authentication.usernameField]
|
|
XCTAssertTrue(usernameField.exists, "Username field should be visible on login screen after logout")
|
|
}
|
|
|
|
/// Test 2: Can type in username and password fields
|
|
func testCanTypeInLoginFields() {
|
|
let usernameField = app.textFields[AccessibilityIdentifiers.Authentication.usernameField]
|
|
usernameField.waitForExistenceOrFail(timeout: defaultTimeout, message: "Username field should exist on login screen")
|
|
usernameField.focusAndType("testuser", app: app)
|
|
|
|
let passwordField = app.secureTextFields[AccessibilityIdentifiers.Authentication.passwordField].exists
|
|
? app.secureTextFields[AccessibilityIdentifiers.Authentication.passwordField]
|
|
: app.textFields[AccessibilityIdentifiers.Authentication.passwordField]
|
|
XCTAssertTrue(passwordField.exists, "Password field should exist on login screen")
|
|
passwordField.focusAndType("testpass123", app: app)
|
|
|
|
let signInButton = app.buttons[AccessibilityIdentifiers.Authentication.loginButton]
|
|
XCTAssertTrue(signInButton.exists, "Login button should exist on login screen")
|
|
}
|
|
}
|