1
1
mirror of https://github.com/github/semantic.git synced 2024-12-19 04:41:47 +03:00
semantic/prototype/DoubtTests/DiffTests.swift

64 lines
1.8 KiB
Swift
Raw Normal View History

final class DiffTests: XCTestCase {
func testSESOverEmptyCollectionsIsEmpty() {
assert(SES([], []), ==, [])
}
func testSESOverEmptyAndNonEmptyCollectionsIsInsertions() {
2015-10-06 20:22:54 +03:00
assert(SES([], [ a, b ]), ==, [ insert(a), insert(b) ])
}
2015-09-16 17:04:30 +03:00
func testSESOverNonEmptyAndEmptyCollectionsIsDeletions() {
2015-10-06 20:22:54 +03:00
assert(SES([ a, b ], []), ==, [ Diff.Pure(.Delete(a)), Diff.Pure(.Delete(b)) ])
2015-09-16 17:04:30 +03:00
}
2015-09-17 22:55:30 +03:00
func testSESCanInsertAtHead() {
2015-10-06 20:25:27 +03:00
assert(SES([ a, b, c ], [ d, a, b, c ]), ==, [ insert(d), roll(a), roll(b), roll(c) ])
2015-09-17 22:55:30 +03:00
}
2015-09-17 22:56:01 +03:00
func testSESCanDeleteAtHead() {
2015-10-06 20:25:27 +03:00
assert(SES([ d, a, b, c ], [ a, b, c ]), ==, [ delete(d), roll(a), roll(b), roll(c) ])
2015-09-17 22:56:01 +03:00
}
func testSESCanInsertInMiddle() {
2015-10-06 20:25:56 +03:00
assert(SES([ a, b, c ], [ a, d, b, c ]), ==, [ roll(a), insert(d), roll(b), roll(c) ])
}
func testSESCanDeleteInMiddle() {
2015-10-06 20:25:56 +03:00
assert(SES([ a, d, b, c ], [ a, b, c ]), ==, [ roll(a), delete(d), roll(b), roll(c) ])
}
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-10-06 20:22:37 +03:00
private func insert(term: Term) -> Diff {
return Diff.Pure(.Insert(term))
}
private func delete(term: Term) -> Diff {
return Diff.Pure(.Delete(term))
}
private func roll(term: Term) -> Diff {
return Diff.Roll(term.out.map(roll))
2015-10-06 20:22:37 +03:00
}
2015-10-06 19:57:48 +03:00
private typealias Term = Fix<Info>
2015-10-06 20:16:32 +03:00
private typealias Diff = Free<Info, Patch<Info>>
2015-10-06 19:57:48 +03:00
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", [])))
private func SES(a: [Term], _ b: [Term]) -> [Diff] {
return SES(a, b, equals: ==, recur: { Diff.Pure(Patch.Replace($0, $1)) })
}
2015-10-06 20:16:23 +03:00
import Assertions
2015-10-06 20:10:45 +03:00
@testable import Doubt
import XCTest