summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLudovic Courtès <ludo@gnu.org>2022-09-21 17:21:48 +0200
committerLudovic Courtès <ludo@gnu.org>2022-09-24 17:59:04 +0200
commit08023bcab35faafcf3e9c77babe910d9ece240d2 (patch)
tree4a70793c94306d6682a1e599691d2942755f0534
parent95e06bc3e1a4fda2b010d69776187ec2e1b02c1b (diff)
substitute: Test behavior with unroutable substitute server addresses.
* tests/substitute.scm (%unroutable-substitute-url): New variable. ("query narinfo signed with authorized key, unroutable URL first") ("substitute, authorized key, first substitute URL is unroutable"): New tests.
-rw-r--r--tests/substitute.scm46
1 files changed, 46 insertions, 0 deletions
diff --git a/tests/substitute.scm b/tests/substitute.scm
index 049e6ba762..5315292987 100644
--- a/tests/substitute.scm
+++ b/tests/substitute.scm
@@ -137,6 +137,12 @@ version identifier.."
(string-append (dirname %main-substitute-directory)
"/substituter-alt-data"))
+(define %unroutable-substitute-url
+ ;; Substitute URL with an unroutable server address, as per
+ ;; <https://www.rfc-editor.org/rfc/rfc5737>.
+ "http://203.0.113.1")
+
+
(define %narinfo
;; Skeleton of the narinfo used below.
(string-append "StorePath: " (%store-prefix)
@@ -305,6 +311,24 @@ Deriver: " (%store-prefix) "/foo.drv")
(lambda ()
(guix-substitute "--query"))))))))
+(test-equal "query narinfo signed with authorized key, unroutable URL first"
+ (string-append (%store-prefix) "/aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa-foo")
+
+ (with-narinfo (string-append %narinfo "Signature: "
+ (signature-field %narinfo)
+ "\n")
+ (string-trim-both
+ (with-output-to-string
+ (lambda ()
+ (with-input-from-string (string-append "have " (%store-prefix)
+ "/aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa-foo")
+ (lambda ()
+ (parameterize ((substitute-urls
+ (list %unroutable-substitute-url
+ (string-append "file://"
+ %main-substitute-directory))))
+ (guix-substitute "--query")))))))))
+
(test-equal "query narinfo signed with unauthorized key"
"" ; not substitutable
@@ -417,6 +441,28 @@ System: mips64el-linux\n")))
(lambda ()
(false-if-exception (delete-file "substitute-retrieved"))))))
+(test-equal "substitute, authorized key, first substitute URL is unroutable"
+ '("Substitutable data." 1 #o444)
+ (with-narinfo (string-append %narinfo "Signature: "
+ (signature-field %narinfo))
+ (dynamic-wind
+ (const #t)
+ (lambda ()
+ ;; Pick an unroutable URL as the first one. This shouldn't be a
+ ;; problem.
+ (parameterize ((substitute-urls
+ (list %unroutable-substitute-url
+ (string-append "file://"
+ %main-substitute-directory))))
+ (request-substitution (string-append (%store-prefix)
+ "/aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa-foo")
+ "substitute-retrieved")
+ (list (call-with-input-file "substitute-retrieved" get-string-all)
+ (stat:mtime (lstat "substitute-retrieved"))
+ (stat:perms (lstat "substitute-retrieved")))))
+ (lambda ()
+ (false-if-exception (delete-file "substitute-retrieved"))))))
+
(test-equal "substitute, unauthorized narinfo comes first"
"Substitutable data."
(with-narinfo*