Skip to content

Commit a7648c7

Browse files
committed
Auto merge of #6980 - Eh2406:varisat, r=alexcrichton
Test the Resolver against the varisat Library Resolution can be reduced to the SAT problem. So this is an alternative implementation of the resolver that uses a SAT library for the hard work. This is intended to be easy to read, as compared to the real resolver, and run as part of the test sweet to make sure the real resolver works as expected. Part of #6120. Some notes on performance: The initial version did not support public & private deps: ~64 loc, `O(nln(n))` vars, `O(nln(n) + n*d)` clauses, 0.5x slower on `prop_passes_validation` The final version: ~163 loc, `O(dn^2`) vars, `O(dn^3)` clauses, 1.5x slower on `prop_passes_validation` That comparison makes me feel better about spending months trying to get public & private deps to be fast enough for stabilization.
2 parents 66ff186 + e08d032 commit a7648c7

File tree

3 files changed

+323
-28
lines changed

3 files changed

+323
-28
lines changed

Cargo.toml

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -103,6 +103,7 @@ features = [
103103
[dev-dependencies]
104104
bufstream = "0.1"
105105
proptest = "0.9.1"
106+
varisat = "0.2.1"
106107

107108
[[bin]]
108109
name = "cargo"

tests/testsuite/resolve.rs

Lines changed: 20 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -9,7 +9,7 @@ use crate::support::registry::Package;
99
use crate::support::resolver::{
1010
assert_contains, assert_same, dep, dep_kind, dep_loc, dep_req, dep_req_kind, loc_names, names,
1111
pkg, pkg_dep, pkg_id, pkg_loc, registry, registry_strategy, remove_dep, resolve,
12-
resolve_and_validated, resolve_with_config, PrettyPrintRegistry, ToDep, ToPkgId,
12+
resolve_and_validated, resolve_with_config, PrettyPrintRegistry, SatResolve, ToDep, ToPkgId,
1313
};
1414

1515
use proptest::prelude::*;
@@ -41,6 +41,7 @@ proptest! {
4141
PrettyPrintRegistry(input) in registry_strategy(50, 20, 60)
4242
) {
4343
let reg = registry(input.clone());
44+
let mut sat_resolve = SatResolve::new(&reg);
4445
// there is only a small chance that any one
4546
// crate will be interesting.
4647
// So we try some of the most complicated.
@@ -49,6 +50,7 @@ proptest! {
4950
pkg_id("root"),
5051
vec![dep_req(&this.name(), &format!("={}", this.version()))],
5152
&reg,
53+
Some(&mut sat_resolve),
5254
);
5355
}
5456
}
@@ -236,6 +238,18 @@ proptest! {
236238
}
237239
}
238240

241+
#[test]
242+
fn pub_fail() {
243+
let input = vec![
244+
pkg!(("a", "0.0.4")),
245+
pkg!(("a", "0.0.5")),
246+
pkg!(("e", "0.0.6") => [dep_req_kind("a", "<= 0.0.4", Kind::Normal, true),]),
247+
pkg!(("kB", "0.0.3") => [dep_req("a", ">= 0.0.5"),dep("e"),]),
248+
];
249+
let reg = registry(input.clone());
250+
assert!(resolve_and_validated(pkg_id("root"), vec![dep("kB")], &reg, None).is_err());
251+
}
252+
239253
#[test]
240254
fn basic_public_dependency() {
241255
let reg = registry(vec![
@@ -245,7 +259,7 @@ fn basic_public_dependency() {
245259
pkg!("C" => [dep("A"), dep("B")]),
246260
]);
247261

248-
let res = resolve_and_validated(pkg_id("root"), vec![dep("C")], &reg).unwrap();
262+
let res = resolve_and_validated(pkg_id("root"), vec![dep("C")], &reg, None).unwrap();
249263
assert_same(
250264
&res,
251265
&names(&[
@@ -281,7 +295,7 @@ fn public_dependency_filling_in() {
281295
pkg!("d" => [dep("c"), dep("a"), dep("b")]),
282296
]);
283297

284-
let res = resolve_and_validated(pkg_id("root"), vec![dep("d")], &reg).unwrap();
298+
let res = resolve_and_validated(pkg_id("root"), vec![dep("d")], &reg, None).unwrap();
285299
assert_same(
286300
&res,
287301
&names(&[
@@ -316,7 +330,7 @@ fn public_dependency_filling_in_and_update() {
316330
pkg!("C" => [dep("A"),dep("B")]),
317331
pkg!("D" => [dep("B"),dep("C")]),
318332
]);
319-
let res = resolve_and_validated(pkg_id("root"), vec![dep("D")], &reg).unwrap();
333+
let res = resolve_and_validated(pkg_id("root"), vec![dep("D")], &reg, None).unwrap();
320334
assert_same(
321335
&res,
322336
&names(&[
@@ -1407,7 +1421,7 @@ fn conflict_store_bug() {
14071421
];
14081422

14091423
let reg = registry(input);
1410-
let _ = resolve_and_validated(pkg_id("root"), vec![dep("j")], &reg);
1424+
let _ = resolve_and_validated(pkg_id("root"), vec![dep("j")], &reg, None);
14111425
}
14121426

14131427
#[test]
@@ -1435,5 +1449,5 @@ fn conflict_store_more_then_one_match() {
14351449
]),
14361450
];
14371451
let reg = registry(input);
1438-
let _ = resolve_and_validated(pkg_id("root"), vec![dep("nA")], &reg);
1452+
let _ = resolve_and_validated(pkg_id("root"), vec![dep("nA")], &reg, None);
14391453
}

0 commit comments

Comments
 (0)