Actually test requirement parsing output (not just if it succeded)

This commit is contained in:
a dinosaur 2025-07-06 17:01:19 +10:00
parent 058f9070ad
commit d850b9998d
3 changed files with 32 additions and 20 deletions

View File

@ -5,7 +5,7 @@
import Foundation
internal struct ApkVersionRequirement: Hashable {
internal struct ApkVersionRequirement: Sendable, Hashable {
let name: String
let versionSpec: ApkVersionSpecification

View File

@ -3,13 +3,13 @@
* SPDX-License-Identifier: Apache-2.0
*/
enum ApkVersionSpecification: Equatable, Hashable {
case any(invert: Bool)
case constraint(invert: Bool, op: Operator, version: String)
enum ApkVersionSpecification: Equatable, Hashable, Sendable {
case any(invert: Bool = false)
case constraint(invert: Bool = false, op: Operator, version: String)
}
extension ApkVersionSpecification {
enum Operator: Equatable {
enum Operator: Equatable, Sendable {
case equals
case fuzzyEquals
case greater

View File

@ -7,21 +7,33 @@ import Testing
@testable import darwin_apk
@Test func testParseDependency() {
for valid in [
"bash",
"libapparmor=4.1.0-r2",
"python3~3.12",
"so:libc.musl-x86_64.so.1",
"!alsa-lib<1.2.14-r0",
"!alsa-lib>1.2.14-r0",
"!lld20-libs<20.1.2-r0",
"!lld20-libs>20.1.2-r0",
"!lld20<20.1.2-r0",
"!lld20>20.1.2-r0",
] {
#expect(throws: Never.self, "Expected valid: \(valid)") {
try ApkVersionRequirement(extract: valid[...])
}
let tests: [String: ApkVersionRequirement] = [
"bash":
.init(name: "bash", spec: .any()),
"!libdbus":
.init(name: "libdbus", spec: .any(invert: true)),
"libapparmor=4.1.0-r2":
.init(name: "libapparmor", spec: .constraint(op: .equals, version: "4.1.0-r2")),
"python3~3.12":
.init(name: "python3", spec: .constraint(op: .fuzzyEquals, version: "3.12")),
"so:libc.musl-x86_64.so.1":
.init(name: "so:libc.musl-x86_64.so.1", spec: .any()),
"!alsa-lib<1.2.14-r0":
.init(name: "alsa-lib", spec: .constraint(invert: true, op: .less, version: "1.2.14-r0")),
"!alsa-lib>1.2.14-r0":
.init(name: "alsa-lib", spec: .constraint(invert: true, op: .greater, version: "1.2.14-r0")),
"!lld20-libs<20.1.2-r0":
.init(name: "lld20-libs", spec: .constraint(invert: true, op: .less, version: "20.1.2-r0")),
"!lld20-libs>20.1.2-r0":
.init(name: "lld20-libs", spec: .constraint(invert: true, op: .greater, version: "20.1.2-r0")),
"!lld20<20.1.2-r0":
.init(name: "lld20", spec: .constraint(invert: true, op: .less, version: "20.1.2-r0")),
"!lld20>20.1.2-r0":
.init(name: "lld20", spec: .constraint(invert: true, op: .greater, version: "20.1.2-r0")),
]
for valid in tests {
#expect((try? ApkVersionRequirement(extract: valid.key[...])) == valid.value,
"Expect: \(valid.key) == \(valid.value)")
}
}