File: KeyedPairTests.swift

package info (click to toggle)
swiftlang 6.0.3-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 2,519,992 kB
  • sloc: cpp: 9,107,863; ansic: 2,040,022; asm: 1,135,751; python: 296,500; objc: 82,456; f90: 60,502; lisp: 34,951; pascal: 19,946; sh: 18,133; perl: 7,482; ml: 4,937; javascript: 4,117; makefile: 3,840; awk: 3,535; xml: 914; fortran: 619; cs: 573; ruby: 573
file content (44 lines) | stat: -rw-r--r-- 1,438 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
/*
 This source file is part of the Swift.org open source project

 Copyright 2016 Apple Inc. and the Swift project authors
 Licensed under Apache License v2.0 with Runtime Library Exception

 See http://swift.org/LICENSE.txt for license information
 See http://swift.org/CONTRIBUTORS.txt for Swift project authors
*/

import XCTest

import TSCBasic

class KeyedPairTests: XCTestCase {
    func testBasics() {
        class Airport {
            // The name of the airport.
            let name: String
            // The destination airports for outgoing flights.
            var destinations: [Airport] = []

            init(name: String) {
                self.name = name
            }
        }

        func whereCanIGo(from airport: Airport) -> [Airport] {
            let closure = transitiveClosure([KeyedPair(airport, key: airport.name)]) {
                return $0.item.destinations.map{ KeyedPair($0, key: $0.name) }
            }
            return closure.map{ $0.item }
        }

        let sf = Airport(name: "San Francisco")
        let beijing = Airport(name: "北京市")
        let newDelhi = Airport(name: "नई दिल्ली")
        let moscow = Airport(name: "Москва")
        sf.destinations = [newDelhi]
        newDelhi.destinations = [beijing, moscow]

        XCTAssertEqual(whereCanIGo(from: sf).map{ $0.name }.sorted(), ["Москва", "नई दिल्ली", "北京市"])
    }
}