2015-09-16 16:56:28 +03:00
|
|
|
final class DiffTests: XCTestCase {
|
|
|
|
func testSESOverEmptyCollectionsIsEmpty() {
|
|
|
|
XCTAssertEqual(Diff.diff([], []), [])
|
|
|
|
}
|
2015-09-16 17:02:20 +03:00
|
|
|
|
|
|
|
func testSESOverEmptyAndNonEmptyCollectionsIsInsertions() {
|
2015-10-02 19:37:09 +03:00
|
|
|
XCTAssertEqual(Diff.diff([], [ a, b ]), [ Diff.Patch(nil, a), Diff.Patch(nil, b) ])
|
2015-09-16 17:02:20 +03:00
|
|
|
}
|
2015-09-16 17:04:30 +03:00
|
|
|
|
|
|
|
func testSESOverNonEmptyAndEmptyCollectionsIsDeletions() {
|
2015-10-02 19:37:09 +03:00
|
|
|
XCTAssertEqual(Diff.diff([ a, b ], []), [ Diff.Patch(a, nil), Diff.Patch(b, nil) ])
|
2015-09-16 17:04:30 +03:00
|
|
|
}
|
2015-09-17 22:55:30 +03:00
|
|
|
|
|
|
|
func testSESCanInsertAtHead() {
|
|
|
|
XCTAssertEqual(Diff.diff([ a, b, c ], [ d, a, b, c ]), [ Diff.Insert(d), Diff(a), Diff(b), Diff(c) ])
|
|
|
|
}
|
2015-09-17 22:56:01 +03:00
|
|
|
|
|
|
|
func testSESCanDeleteAtHead() {
|
|
|
|
XCTAssertEqual(Diff.diff([ d, a, b, c ], [ a, b, c ]), [ Diff.Delete(d), Diff(a), Diff(b), Diff(c) ])
|
|
|
|
}
|
2015-09-17 22:56:53 +03:00
|
|
|
|
|
|
|
func testSESCanInsertInMiddle() {
|
|
|
|
XCTAssertEqual(Diff.diff([ a, b, c ], [ a, d, b, c ]), [ Diff(a), Diff.Insert(d), Diff(b), Diff(c) ])
|
|
|
|
}
|
|
|
|
|
|
|
|
func testSESCanDeleteInMiddle() {
|
|
|
|
XCTAssertEqual(Diff.diff([ a, d, b, c ], [ a, b, c ]), [ Diff(a), Diff.Delete(d), Diff(b), Diff(c) ])
|
|
|
|
}
|
2015-09-28 21:28:36 +03:00
|
|
|
|
|
|
|
func testSESOfLongerSequences() {
|
|
|
|
// fixme: this is awfully slow for such a short sequence
|
|
|
|
XCTAssertEqual(Diff.diff([ a, b, c, a, b, b, a ], [ c, b, a, b, a, c ]), [ Diff.Patch(a, c), Diff(b), Diff.Delete(c), Diff(a), Diff.Delete(b), Diff(b), Diff(a), Diff.Insert(c) ])
|
|
|
|
}
|
2015-09-16 16:56:28 +03:00
|
|
|
}
|
|
|
|
|
2015-10-06 19:57:48 +03:00
|
|
|
private typealias Term = Fix<Info>
|
|
|
|
|
2015-10-06 19:58:07 +03:00
|
|
|
private let a = Term.In(.Leaf(.Literal("a", [])))
|
|
|
|
private let b = Term.In(.Leaf(.Literal("b", [])))
|
|
|
|
private let c = Term.In(.Leaf(.Literal("c", [])))
|
|
|
|
private let d = Term.In(.Leaf(.Literal("d", [])))
|
|
|
|
|
2015-09-16 17:02:20 +03:00
|
|
|
|
2015-10-06 20:10:45 +03:00
|
|
|
@testable import Doubt
|
2015-09-16 16:56:28 +03:00
|
|
|
import XCTest
|