lint: source: Validate URLs of Git references.

Until now the 'source' checker would look at URL for 'url-fetch' origins
but not for 'git-fetch' origins.

* guix/lint.scm (check-source): Add case for 'git-reference?'.
* tests/lint.scm ("source, git-reference: 301 -> 200"): New test.
This commit is contained in:
Ludovic Courtès 2020-07-12 22:41:09 +02:00
parent 7bbe4655a8
commit c10526672e
No known key found for this signature in database
GPG key ID: 090B11993D9AEBB5
2 changed files with 45 additions and 20 deletions

View file

@ -793,8 +793,9 @@ (define (warnings-for-uris uris)
(loop rest (cons warning warnings)))))))) (loop rest (cons warning warnings))))))))
(let ((origin (package-source package))) (let ((origin (package-source package)))
(if (and (origin? origin) (if (origin? origin)
(eqv? (origin-method origin) url-fetch)) (cond
((eq? (origin-method origin) url-fetch)
(let* ((uris (append-map (cut maybe-expand-mirrors <> %mirrors) (let* ((uris (append-map (cut maybe-expand-mirrors <> %mirrors)
(map string->uri (origin-uris origin)))) (map string->uri (origin-uris origin))))
(warnings (warnings-for-uris uris))) (warnings (warnings-for-uris uris)))
@ -812,8 +813,12 @@ (define (warnings-for-uris uris)
(G_ "all the source URIs are unreachable:") (G_ "all the source URIs are unreachable:")
#:field 'source) #:field 'source)
warnings) warnings)
'()))
'()))) '())))
((git-reference? (origin-uri origin))
(warnings-for-uris
(list (string->uri (git-reference-url (origin-uri origin))))))
(else
'())))))
(define (check-source-file-name package) (define (check-source-file-name package)
"Emit a warning if PACKAGE's origin has no meaningful file name." "Emit a warning if PACKAGE's origin has no meaningful file name."

View file

@ -697,6 +697,26 @@ (define (warning-contains? str warnings)
(and (? lint-warning?) second-warning)) (and (? lint-warning?) second-warning))
(lint-warning-message second-warning))))))))) (lint-warning-message second-warning)))))))))
(test-skip (if (http-server-can-listen?) 0 1))
(test-equal "source, git-reference: 301 -> 200"
"permanent redirect from http://localhost:10000/foo/bar to http://localhost:9999/foo/bar"
(with-http-server `((200 ,%long-string))
(let* ((initial-url (%local-url))
(redirect (build-response #:code 301
#:headers
`((location
. ,(string->uri initial-url))))))
(parameterize ((%http-server-port (+ 1 (%http-server-port))))
(with-http-server `((,redirect ""))
(let ((pkg (dummy-package
"x"
(source (origin
(method git-fetch)
(uri (git-reference (url (%local-url))
(commit "v1.0.0")))
(sha256 %null-sha256))))))
(single-lint-warning-message (check-source pkg))))))))
(test-skip (if (http-server-can-listen?) 0 1)) (test-skip (if (http-server-can-listen?) 0 1))
(test-equal "source: 301 -> 404" (test-equal "source: 301 -> 404"
"URI http://localhost:10000/foo/bar not reachable: 404 (\"Such is life\")" "URI http://localhost:10000/foo/bar not reachable: 404 (\"Such is life\")"