summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJulian Andres Klode <jak@debian.org>2022-02-10 19:48:23 +0000
committerJulian Andres Klode <jak@debian.org>2022-02-10 19:48:23 +0000
commit0eaf2689fe2833f946c5b1676547be552c331831 (patch)
tree9f7d9c78daf1469db46261a27f95a471550af34f
parenta7320cea1381ab8fc2305f74769c46894b7b831d (diff)
parent24d4cf6216ded26e6a6517a46c6f9115275b7136 (diff)
Merge branch 'fix/externalsatisfy' into 'main'
Allow --solver apt to work on apt satisfy See merge request apt-team/apt!224
-rw-r--r--apt-private/private-source.cc2
-rwxr-xr-xtest/integration/test-apt-get-satisfy89
2 files changed, 63 insertions, 28 deletions
diff --git a/apt-private/private-source.cc b/apt-private/private-source.cc
index e007c542f..14bc5b43e 100644
--- a/apt-private/private-source.cc
+++ b/apt-private/private-source.cc
@@ -740,7 +740,7 @@ bool DoBuildDep(CommandLine &CmdL)
break;
}
}
- std::string const pseudo = "command line argument";
+ std::string const pseudo = "satisfy:command-line";
WriteBuildDependencyPackage(buildDepsPkgFile, pseudo, pseudoArch, BuildDeps);
pseudoPkgs.emplace_back(pseudo, pseudoArch, "");
}
diff --git a/test/integration/test-apt-get-satisfy b/test/integration/test-apt-get-satisfy
index 23daf069a..267760ffd 100755
--- a/test/integration/test-apt-get-satisfy
+++ b/test/integration/test-apt-get-satisfy
@@ -13,9 +13,12 @@ insertinstalledpackage 'conflicts' 'i386' '1' 'Multi-Arch: same'
insertinstalledpackage 'conflicts' 'amd64' '1' 'Multi-Arch: same'
setupaptarchive
-
-testsuccessequal "Reading package lists...
-Building dependency tree...
+testrun() {
+ local TYPE="$1"
+ local HEADER="$2"
+ shift 2
+ msgmsg "$TYPE: Normal"
+ testsuccessequal "$HEADER
The following packages will be REMOVED:
conflicts
The following NEW packages will be installed:
@@ -23,10 +26,9 @@ The following NEW packages will be installed:
0 upgraded, 1 newly installed, 1 to remove and 0 not upgraded.
Remv conflicts [1]
Inst depends (1 stable [i386])
-Conf depends (1 stable [i386])" aptget satisfy --simulate "depends (>= 1)" "Conflicts: conflicts:i386 (>= 1) [i386], conflicts:amd64 (>= 1) [amd64]"
+Conf depends (1 stable [i386])" aptget satisfy --simulate "depends (>= 1)" "Conflicts: conflicts:i386 (>= 1) [i386], conflicts:amd64 (>= 1) [amd64]" "$@"
-testsuccessequal "Reading package lists...
-Building dependency tree...
+ testsuccessequal "$HEADER
The following packages will be REMOVED:
conflicts:amd64
The following NEW packages will be installed:
@@ -34,43 +36,76 @@ The following NEW packages will be installed:
0 upgraded, 1 newly installed, 1 to remove and 0 not upgraded.
Remv conflicts:amd64 [1]
Inst depends:amd64 (1 stable [amd64])
-Conf depends:amd64 (1 stable [amd64])" aptget satisfy --simulate "depends (>= 1)" "Conflicts: conflicts:i386 (>= 1) [i386], conflicts:amd64 (>= 1) [amd64]" --host-architecture amd64
+Conf depends:amd64 (1 stable [amd64])" aptget satisfy --simulate "depends (>= 1)" "Conflicts: conflicts:i386 (>= 1) [i386], conflicts:amd64 (>= 1) [amd64]" --host-architecture amd64 "$@"
-msgmsg "Build profile"
+ msgmsg "$TYPE: Build profile"
-testsuccessequal "Reading package lists...
-Building dependency tree...
-0 upgraded, 0 newly installed, 0 to remove and 0 not upgraded." aptget satisfy --simulate "depends:amd64 <a>, depends:i386 <i>"
+ testsuccessequal "$HEADER
+0 upgraded, 0 newly installed, 0 to remove and 0 not upgraded." aptget satisfy --simulate "depends:amd64 <a>, depends:i386 <i>" "$@"
-testsuccessequal "Reading package lists...
-Building dependency tree...
+ testsuccessequal "$HEADER
The following NEW packages will be installed:
depends:amd64
0 upgraded, 1 newly installed, 0 to remove and 0 not upgraded.
Inst depends:amd64 (1 stable [amd64])
-Conf depends:amd64 (1 stable [amd64])" aptget satisfy --simulate "depends:amd64 <a>, depends:i386 <i>" -P a
+Conf depends:amd64 (1 stable [amd64])" aptget satisfy --simulate "depends:amd64 <a>, depends:i386 <i>" -P a "$@"
-testsuccessequal "Reading package lists...
-Building dependency tree...
+ testsuccessequal "$HEADER
The following NEW packages will be installed:
depends
0 upgraded, 1 newly installed, 0 to remove and 0 not upgraded.
Inst depends (1 stable [i386])
-Conf depends (1 stable [i386])" aptget satisfy --simulate "depends:amd64 <a>, depends:i386 <i>" -P i
+Conf depends (1 stable [i386])" aptget satisfy --simulate "depends:amd64 <a>, depends:i386 <i>" -P i "$@"
+ msgmsg "$TYPE: Broken syntax"
+ testfailureequal "E: Problem parsing dependency: apt (>= 2" aptget satisfy 'foo' 'apt (>= 2' -s "$@"
+ testfailureequal "E: Problem parsing dependency: Conflicts: apt (>= 2" aptget satisfy 'foo' 'Conflicts: apt (>= 2' -s "$@"
-msgmsg "Broken syntax"
-testfailureequal "E: Problem parsing dependency: apt (>= 2" aptget satisfy 'foo' 'apt (>= 2' -s
-testfailureequal "E: Problem parsing dependency: Conflicts: apt (>= 2" aptget satisfy 'foo' 'Conflicts: apt (>= 2' -s
+ msgmsg "$TYPE: Legacy operators"
+ testfailureequal "E: Invalid operator '<' at offset 5, did you mean '<<' or '<='? - in: foo (< 1)" aptget satisfy 'foo (< 1)' -s "$@"
+ testfailureequal "E: Invalid operator '>' at offset 5, did you mean '>>' or '>='? - in: foo (> 1)" aptget satisfy 'foo (> 1)' -s "$@"
+ msgmsg "$TYPE: Unsupported dependency type"
+ testfailureequal "E: Problem parsing dependency: Recommends: foo" aptget satisfy 'Recommends: foo' -s "$@"
-msgmsg "Legacy operators"
-testfailureequal "E: Invalid operator '<' at offset 5, did you mean '<<' or '<='? - in: foo (< 1)" aptget satisfy 'foo (< 1)' -s
-testfailureequal "E: Invalid operator '>' at offset 5, did you mean '>>' or '>='? - in: foo (> 1)" aptget satisfy 'foo (> 1)' -s
+ msgmsg "$TYPE: Empty dependency"
+ testfailureequal "E: Problem parsing dependency: " aptget satisfy '' -s "$@"
+}
-msgmsg "Unsupported dependency type"
-testfailureequal "E: Problem parsing dependency: Recommends: foo" aptget satisfy 'Recommends: foo' -s
+testrun 'Internal' 'Reading package lists...
+Building dependency tree...'
+testrun 'External' 'Reading package lists...
+Building dependency tree...
+Execute external solver...' --solver apt
+
+testfailureequal "Reading package lists...
+Building dependency tree...
+Some packages could not be installed. This may mean that you have
+requested an impossible situation or if you are using the unstable
+distribution that some required packages have not yet been created
+or been moved out of Incoming.
+The following information may help to resolve the situation:
-msgmsg "Empty dependency"
-testfailureequal "E: Problem parsing dependency: " aptget satisfy '' -s
+The following packages have unmet dependencies:
+ satisfy:command-line : Depends: depends (>= 2) but it is not going to be installed
+E: Unable to correct problems, you have held broken packages." aptget satisfy --simulate "depends (>= 2)" "Conflicts: conflicts:i386 (>= 1) [i386], conflicts:amd64 (>= 1) [amd64]"
+
+testfailureequal "Reading package lists...
+Building dependency tree...
+Execute external solver...
+The solver encountered an error of type: ERR_UNSOLVABLE
+The following information might help you to understand what is wrong:
+The following packages have unmet dependencies:
+ satisfy:command-line : Depends: depends (>= 2) but it is not going to be installed
+
+Some packages could not be installed. This may mean that you have
+requested an impossible situation or if you are using the unstable
+distribution that some required packages have not yet been created
+or been moved out of Incoming.
+The following information may help to resolve the situation:
+
+The following packages have unmet dependencies:
+ satisfy:command-line : Depends: depends (>= 2) but it is not going to be installed
+ Conflicts: conflicts:i386 (>= 1)
+E: External solver failed with: The following packages have unmet dependencies:" aptget satisfy --simulate "depends (>= 2)" "Conflicts: conflicts:i386 (>= 1) [i386], conflicts:amd64 (>= 1) [amd64]" --solver apt