141 lines
4.7 KiB
Swift
141 lines
4.7 KiB
Swift
|
//
|
||
|
// SnapshotHelper.swift
|
||
|
// Example
|
||
|
//
|
||
|
// Created by Felix Krause on 10/8/15.
|
||
|
// Copyright © 2015 Felix Krause. All rights reserved.
|
||
|
//
|
||
|
|
||
|
// This file should be used if your UI Tests are written in Swift 2.3
|
||
|
|
||
|
import Foundation
|
||
|
import XCTest
|
||
|
|
||
|
var deviceLanguage = ""
|
||
|
var locale = ""
|
||
|
|
||
|
@available(*, deprecated, message="use setupSnapshot: instead")
|
||
|
func setLanguage(app: XCUIApplication) {
|
||
|
setupSnapshot(app)
|
||
|
}
|
||
|
|
||
|
func setupSnapshot(app: XCUIApplication) {
|
||
|
Snapshot.setupSnapshot(app)
|
||
|
}
|
||
|
|
||
|
func snapshot(name: String, waitForLoadingIndicator: Bool = true) {
|
||
|
Snapshot.snapshot(name, waitForLoadingIndicator: waitForLoadingIndicator)
|
||
|
}
|
||
|
|
||
|
public class Snapshot: NSObject {
|
||
|
|
||
|
public class func setupSnapshot(app: XCUIApplication) {
|
||
|
setLanguage(app)
|
||
|
setLocale(app)
|
||
|
setLaunchArguments(app)
|
||
|
}
|
||
|
|
||
|
class func setLanguage(app: XCUIApplication) {
|
||
|
guard let prefix = pathPrefix() else {
|
||
|
return
|
||
|
}
|
||
|
|
||
|
let path = prefix.stringByAppendingPathComponent("language.txt")
|
||
|
|
||
|
do {
|
||
|
let trimCharacterSet = NSCharacterSet.whitespaceAndNewlineCharacterSet()
|
||
|
deviceLanguage = try NSString(contentsOfFile: path, encoding: NSUTF8StringEncoding).stringByTrimmingCharactersInSet(trimCharacterSet) as String
|
||
|
app.launchArguments += ["-AppleLanguages", "(\(deviceLanguage))"]
|
||
|
} catch {
|
||
|
print("Couldn't detect/set language...")
|
||
|
}
|
||
|
}
|
||
|
|
||
|
class func setLocale(app: XCUIApplication) {
|
||
|
guard let prefix = pathPrefix() else {
|
||
|
return
|
||
|
}
|
||
|
|
||
|
let path = prefix.stringByAppendingPathComponent("locale.txt")
|
||
|
|
||
|
do {
|
||
|
let trimCharacterSet = NSCharacterSet.whitespaceAndNewlineCharacterSet()
|
||
|
locale = try NSString(contentsOfFile: path, encoding: NSUTF8StringEncoding).stringByTrimmingCharactersInSet(trimCharacterSet) as String
|
||
|
} catch {
|
||
|
print("Couldn't detect/set locale...")
|
||
|
}
|
||
|
if locale.isEmpty {
|
||
|
locale = NSLocale(localeIdentifier: deviceLanguage).localeIdentifier
|
||
|
}
|
||
|
app.launchArguments += ["-AppleLocale", "\"\(locale)\""]
|
||
|
}
|
||
|
|
||
|
class func setLaunchArguments(app: XCUIApplication) {
|
||
|
guard let prefix = pathPrefix() else {
|
||
|
return
|
||
|
}
|
||
|
|
||
|
let path = prefix.stringByAppendingPathComponent("snapshot-launch_arguments.txt")
|
||
|
app.launchArguments += ["-FASTLANE_SNAPSHOT", "YES", "-ui_testing"]
|
||
|
|
||
|
do {
|
||
|
let launchArguments = try NSString(contentsOfFile: path, encoding: NSUTF8StringEncoding) as String
|
||
|
let regex = try NSRegularExpression(pattern: "(\\\".+?\\\"|\\S+)", options: [])
|
||
|
let matches = regex.matchesInString(launchArguments, options: [], range: NSRange(location:0, length:launchArguments.characters.count))
|
||
|
let results = matches.map { result -> String in
|
||
|
(launchArguments as NSString).substringWithRange(result.range)
|
||
|
}
|
||
|
app.launchArguments += results
|
||
|
} catch {
|
||
|
print("Couldn't detect/set launch_arguments...")
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public class func snapshot(name: String, waitForLoadingIndicator: Bool = true) {
|
||
|
if waitForLoadingIndicator {
|
||
|
waitForLoadingIndicatorToDisappear()
|
||
|
}
|
||
|
|
||
|
print("snapshot: \(name)") // more information about this, check out https://github.com/fastlane/fastlane/tree/master/snapshot#how-does-it-work
|
||
|
|
||
|
sleep(1) // Waiting for the animation to be finished (kind of)
|
||
|
|
||
|
#if os(tvOS)
|
||
|
XCUIApplication().childrenMatchingType(.Browser).count
|
||
|
#else
|
||
|
XCUIDevice.sharedDevice().orientation = .Unknown
|
||
|
#endif
|
||
|
}
|
||
|
|
||
|
class func waitForLoadingIndicatorToDisappear() {
|
||
|
#if os(tvOS)
|
||
|
return
|
||
|
#endif
|
||
|
|
||
|
let query = XCUIApplication().statusBars.childrenMatchingType(.Other).elementBoundByIndex(1).childrenMatchingType(.Other)
|
||
|
|
||
|
while (0..<query.count).map({ query.elementBoundByIndex($0) }).contains({ $0.isLoadingIndicator }) {
|
||
|
sleep(1)
|
||
|
print("Waiting for loading indicator to disappear...")
|
||
|
}
|
||
|
}
|
||
|
|
||
|
class func pathPrefix() -> NSString? {
|
||
|
if let path = NSProcessInfo().environment["SIMULATOR_HOST_HOME"] as NSString? {
|
||
|
return path.stringByAppendingPathComponent("Library/Caches/tools.fastlane")
|
||
|
}
|
||
|
print("Couldn't find Snapshot configuration files at ~/Library/Caches/tools.fastlane")
|
||
|
return nil
|
||
|
}
|
||
|
}
|
||
|
|
||
|
extension XCUIElement {
|
||
|
var isLoadingIndicator: Bool {
|
||
|
return self.frame.size == CGSize(width: 10, height: 20)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Please don't remove the lines below
|
||
|
// They are used to detect outdated configuration files
|
||
|
// SnapshotHelperVersion [1.2]
|