SwiftLint/Tests/SwiftLintFrameworkTests/CollectingRuleTests.swift

126 lines
5.2 KiB
Swift

@testable import SwiftLintFramework
import XCTest
// swiftlint:disable nesting
class CollectingRuleTests: XCTestCase {
func testCollectsIntoStorage() {
struct Spec: MockCollectingRule {
func collectInfo(for file: SwiftLintFile) -> Int {
return 42
}
func validate(file: SwiftLintFile, collectedInfo: [SwiftLintFile: Int]) -> [StyleViolation] {
XCTAssertEqual(collectedInfo[file], 42)
return [StyleViolation(ruleDescription: Spec.description,
location: Location(file: file, byteOffset: 0))]
}
}
XCTAssertFalse(violations(Example(""), config: Spec.configuration!).isEmpty)
}
func testCollectsAllFiles() {
struct Spec: MockCollectingRule {
func collectInfo(for file: SwiftLintFile) -> String {
return file.contents
}
func validate(file: SwiftLintFile, collectedInfo: [SwiftLintFile: String]) -> [StyleViolation] {
let values = collectedInfo.values
XCTAssertTrue(values.contains("foo"))
XCTAssertTrue(values.contains("bar"))
XCTAssertTrue(values.contains("baz"))
return [StyleViolation(ruleDescription: Spec.description,
location: Location(file: file, byteOffset: 0))]
}
}
let inputs = ["foo", "bar", "baz"]
XCTAssertEqual(inputs.violations(config: Spec.configuration!).count, inputs.count)
}
func testCollectsAnalyzerFiles() {
struct Spec: MockCollectingRule & AnalyzerRule {
func collectInfo(for file: SwiftLintFile, compilerArguments: [String]) -> [String] {
return compilerArguments
}
func validate(file: SwiftLintFile, collectedInfo: [SwiftLintFile: [String]], compilerArguments: [String])
-> [StyleViolation] {
XCTAssertEqual(collectedInfo[file], compilerArguments)
return [StyleViolation(ruleDescription: Spec.description,
location: Location(file: file, byteOffset: 0))]
}
}
XCTAssertFalse(violations(Example(""), config: Spec.configuration!, requiresFileOnDisk: true).isEmpty)
}
func testCorrects() {
struct Spec: MockCollectingRule & CollectingCorrectableRule {
func collectInfo(for file: SwiftLintFile) -> String {
return file.contents
}
func validate(file: SwiftLintFile, collectedInfo: [SwiftLintFile: String]) -> [StyleViolation] {
if collectedInfo[file] == "baz" {
return [StyleViolation(ruleDescription: Spec.description,
location: Location(file: file, byteOffset: 2))]
} else {
return []
}
}
func correct(file: SwiftLintFile, collectedInfo: [SwiftLintFile: String]) -> [Correction] {
if collectedInfo[file] == "baz" {
return [Correction(ruleDescription: Spec.description,
location: Location(file: file, byteOffset: 2))]
} else {
return []
}
}
}
struct AnalyzerSpec: MockCollectingRule & AnalyzerRule & CollectingCorrectableRule {
func collectInfo(for file: SwiftLintFile, compilerArguments: [String]) -> String {
return file.contents
}
func validate(file: SwiftLintFile, collectedInfo: [SwiftLintFile: String], compilerArguments: [String])
-> [StyleViolation] {
if collectedInfo[file] == "baz" {
return [StyleViolation(ruleDescription: Spec.description,
location: Location(file: file, byteOffset: 2))]
} else {
return []
}
}
func correct(file: SwiftLintFile, collectedInfo: [SwiftLintFile: String],
compilerArguments: [String]) -> [Correction] {
if collectedInfo[file] == "baz" {
return [Correction(ruleDescription: Spec.description,
location: Location(file: file, byteOffset: 2))]
} else {
return []
}
}
}
let inputs = ["foo", "baz"]
XCTAssertEqual(inputs.corrections(config: Spec.configuration!).count, 1)
XCTAssertEqual(inputs.corrections(config: AnalyzerSpec.configuration!, requiresFileOnDisk: true).count, 1)
}
}
private protocol MockCollectingRule: CollectingRule {}
extension MockCollectingRule {
var configurationDescription: String { return "N/A" }
static var description: RuleDescription {
return RuleDescription(identifier: "test_rule", name: "", description: "", kind: .lint)
}
static var configuration: Configuration? {
return Configuration(rulesMode: .whitelisted([description.identifier]), ruleList: RuleList(rules: self))
}
init(configuration: Any) throws { self.init() }
}