Issue #45
Mock a location
You should mock a location to ensure reliable test
Create the gpx file
Go to Xcode -> File -> New -> GPX File

It looks like
<?xml version="1.0"?>
<gpx version="1.1" creator="Xcode">
  <wpt lat="59.913590" lon="10.733750">
    <name>Oslo S</name>
    <time>2017-05-31T14:55:37Z</time>
  </wpt>
  <wpt lat="59.913590" lon="10.733750">
    <name>Oslo S</name>
    <time>2017-05-31T14:55:40Z</time>
  </wpt>
</gpx>
The gpx file is very powerful, as it allows you to specify a route with different movement speed.
Provide one or more waypoints containing a latitude/longitude pair. If you provide one waypoint, Xcode will simulate that specific location. If you provide multiple waypoints, Xcode will simulate a route visiting each waypoint.
Optionally provide a time element for each waypoint. Xcode will interpolate movement at a rate of speed based on the time elapsed between each waypoint. If you do not provide a time element, then Xcode will use a fixed rate of speed. Waypoints must be sorted by time in ascending order.
Use the gpx file
- Declare the gpxfile in app target, not UITests target. Go to yourapp scheme -> Run -> Options

- Go to Simulator -> Debug -> Location -> Custom Locationand select that same location, just to make sure. It does not need to be the same, but I see that withoutCustom Location, it does not work inUITests
Test that you’re near the initial location
let map = app.maps.element(boundBy: 0)
let predicate = NSPredicate(format: "label CONTAINS 'City Hall'")
let cityHall = map.otherElements.matching(predicate).element(boundBy: 0)
// wait for the map to finish loading and zooming
wait(for: cityHall, timeout: 2)
XCTAssertTrue(cityHall.exists)
The wait function is from https://github.com/onmyway133/blog/issues/44
Test that you can interact with your custom pin
You need to specify accessibilityIdentifier, like
class MyPin: MKAnnotationView {
  override func didMoveToSuperview() {
    super.didMoveToSuperview()
    accessibilityIdentifier = "myPin"
  }
}
and then query for that pin. Not that it is not inside map, it is inside app
let pin = app.otherElements.matching(identifier: "myPin").element(boundBy: 0)
XCTAssertTrue(pin.exists)
You should use accessibilityIdentifier
accessibilityIdentifier is from UIAccessibilityIdentification protocol. You should not use accessibilityLabel, see https://github.com/kif-framework/KIF/issues/243
Given that accessibilityLabel is an outwardly-facing string that is actually used by accessibility screen readers (and should be localized to the device user’s language), Apple now provides an alternate property (iOS 5+) that is specifically intended for UI Automation purposes
Start the conversation