mirror of
https://github.com/element-hq/element-x-ios.git
synced 2025-03-10 21:39:12 +00:00

* Stop running the UI tests on the double localized pseudolanguage * Fix UI tests signalling comms problem because the json key ordering wasn't defined and the messages wouldn't match. * Remove UI tests that are now the same as preview tests (i.e. non flow based, only screen based), fixed the rest so they run on iOS 17.2, the iPhone 15 and iPad 10th gen simulators. * Remove unnecessary gitignore instructions, change UI test snapshot naming convention to be more similar to the unit test ones * Enable derived data and spm checkout caching for UI tests * Switch UI tests back to the perf-only runner, moved the integration tests to the iPhone 15 Pro simulator. * Address PR comments
72 lines
2.5 KiB
Swift
72 lines
2.5 KiB
Swift
//
|
|
// Copyright 2022 New Vector Ltd
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
//
|
|
|
|
import XCTest
|
|
|
|
@MainActor
|
|
class PollFormScreenUITests: XCTestCase {
|
|
func testEmptyScreen() async throws {
|
|
let app = Application.launch(.createPoll)
|
|
try await app.assertScreenshot(.createPoll)
|
|
}
|
|
|
|
func testFilledPoll() async throws {
|
|
let app = Application.launch(.createPoll)
|
|
let questionTextField = app.textViews[A11yIdentifiers.pollFormScreen.question]
|
|
questionTextField.forceTap()
|
|
questionTextField.typeText("Do you like polls?")
|
|
|
|
let option1TextField = app.textViews[A11yIdentifiers.pollFormScreen.optionID(0)]
|
|
option1TextField.forceTap()
|
|
option1TextField.typeText("Yes")
|
|
|
|
let option2TextField = app.textViews[A11yIdentifiers.pollFormScreen.optionID(1)]
|
|
option2TextField.forceTap()
|
|
option2TextField.typeText("No")
|
|
|
|
// Dismiss the keyboard
|
|
app.swipeDown()
|
|
|
|
let createButton = app.buttons[A11yIdentifiers.pollFormScreen.submit]
|
|
XCTAssertTrue(createButton.isEnabled)
|
|
|
|
try await app.assertScreenshot(.createPoll, step: 1)
|
|
}
|
|
|
|
func testMaxOptions() async throws {
|
|
let app = Application.launch(.createPoll)
|
|
let createButton = app.buttons[A11yIdentifiers.pollFormScreen.submit]
|
|
let addOption = app.buttons[A11yIdentifiers.pollFormScreen.addOption]
|
|
|
|
for _ in 1...18 {
|
|
// Use the frame as a fallback to fix the button being obscured by the home indicator.
|
|
if !addOption.isHittable || addOption.frame.maxY > (app.frame.maxY - 20) {
|
|
app.swipeUp()
|
|
}
|
|
addOption.tap()
|
|
}
|
|
|
|
app.swipeDown() // Dismiss the keyboard so the Add button is always visible.
|
|
|
|
app.swipeUp() // Ensures that the bottom is shown.
|
|
|
|
XCTAssertFalse(addOption.exists)
|
|
XCTAssertFalse(createButton.isEnabled)
|
|
|
|
try await app.assertScreenshot(.createPoll, step: 2)
|
|
}
|
|
}
|