Add 5 passing UI tests (batches 1-2) and mark 4 blocked tests RED
Batch 1: TC-035 (donut chart), TC-036 (bar chart) — Year View stats Batch 2: TC-037 (collapse/expand), TC-065 (privacy link), TC-066 (EULA link) Blocked: TC-124, TC-068 (Settings ScrollView tap issue), TC-038 (share sheet) New accessibility IDs: bypass subscription toggle, EULA, privacy policy buttons. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
This commit is contained in:
@@ -2,7 +2,7 @@
|
||||
// YearViewDisplayTests.swift
|
||||
// Tests iOS
|
||||
//
|
||||
// Year View display tests: donut chart, bar chart.
|
||||
// Year View display tests: stats section with donut chart and bar chart.
|
||||
// TC-035, TC-036
|
||||
//
|
||||
|
||||
@@ -13,24 +13,29 @@ final class YearViewDisplayTests: BaseUITestCase {
|
||||
override var bypassSubscription: Bool { true }
|
||||
|
||||
/// TC-035: Year View shows donut chart with mood distribution.
|
||||
/// The donut chart center displays the entry count with "days" text.
|
||||
func testYearView_DonutChartVisible() {
|
||||
let tabBar = TabBarScreen(app: app)
|
||||
tabBar.tapYear()
|
||||
|
||||
// Wait for Year tab to be selected and content to load
|
||||
XCTAssertTrue(tabBar.yearTab.isSelected, "Year tab should be selected")
|
||||
|
||||
captureScreenshot(name: "year_view_loaded")
|
||||
// Wait for stats section to render
|
||||
let statsSection = app.element(UITestID.Year.statsSection)
|
||||
XCTAssertTrue(
|
||||
statsSection.waitForExistence(timeout: 8),
|
||||
"Year stats section should be visible"
|
||||
)
|
||||
|
||||
// The donut chart is inside the stats section of the first YearCard.
|
||||
// Try finding by accessibility identifier first, then fall back to presence of "days" text.
|
||||
let donutChart = app.element(UITestID.Year.donutChart)
|
||||
let found = donutChart.waitForExistence(timeout: 8) ||
|
||||
app.swipeUntilExists(donutChart, direction: .up, maxSwipes: 3, timeoutPerTry: 1.0)
|
||||
// The donut chart center shows "days" — search globally since
|
||||
// SwiftUI flattens the accessibility tree under GeometryReader.
|
||||
let daysLabel = app.staticTexts["days"]
|
||||
XCTAssertTrue(
|
||||
daysLabel.waitForExistence(timeout: 3),
|
||||
"Donut chart should display 'days' label in center"
|
||||
)
|
||||
|
||||
captureScreenshot(name: "year_donut_chart")
|
||||
|
||||
XCTAssertTrue(found, "Donut chart should be visible in Year View")
|
||||
}
|
||||
|
||||
/// TC-036: Year View shows bar chart with mood percentages.
|
||||
@@ -40,12 +45,23 @@ final class YearViewDisplayTests: BaseUITestCase {
|
||||
|
||||
XCTAssertTrue(tabBar.yearTab.isSelected, "Year tab should be selected")
|
||||
|
||||
let barChart = app.element(UITestID.Year.barChart)
|
||||
let found = barChart.waitForExistence(timeout: 8) ||
|
||||
app.swipeUntilExists(barChart, direction: .up, maxSwipes: 3, timeoutPerTry: 1.0)
|
||||
let statsSection = app.element(UITestID.Year.statsSection)
|
||||
XCTAssertTrue(
|
||||
statsSection.waitForExistence(timeout: 8),
|
||||
"Year stats section should be visible"
|
||||
)
|
||||
|
||||
// week_of_moods fixture: 2 great, 2 good, 1 avg, 1 bad, 1 horrible
|
||||
// Expected percentages: 28% (great, good) and 14% (avg, bad, horrible).
|
||||
// Search for any of the expected percentage labels.
|
||||
let found28 = app.staticTexts["28%"].waitForExistence(timeout: 3)
|
||||
let found14 = app.staticTexts["14%"].waitForExistence(timeout: 2)
|
||||
|
||||
captureScreenshot(name: "year_bar_chart")
|
||||
|
||||
XCTAssertTrue(found, "Bar chart should be visible in Year View")
|
||||
XCTAssertTrue(
|
||||
found28 || found14,
|
||||
"Bar chart should show at least one percentage value (28% or 14%)"
|
||||
)
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user