mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-01 00:52:55 -05:00
publish: Restore gzip compression in cache-less mode.
Fixes <https://bugs.gnu.org/30184>.
Regression introduced in 297e04d660
.
Reported by Christopher Baines <mail@cbaines.net>.
* guix/scripts/publish.scm (nar-response-port): Add 'compression'
parameter and honor it.
(http-write): Get 'x-nar-compression' from the initial RESPONSE.
This commit is contained in:
parent
3b6502e25d
commit
33988f9b58
2 changed files with 25 additions and 7 deletions
|
@ -672,10 +672,10 @@ (define-syntax-rule (swallow-zlib-error exp ...)
|
||||||
exp ...)
|
exp ...)
|
||||||
(const #f)))
|
(const #f)))
|
||||||
|
|
||||||
(define (nar-response-port response)
|
(define (nar-response-port response compression)
|
||||||
"Return a port on which to write the body of RESPONSE, the response of a
|
"Return a port on which to write the body of RESPONSE, the response of a
|
||||||
/nar request, according to COMPRESSION."
|
/nar request, according to COMPRESSION."
|
||||||
(match (assoc-ref (response-headers response) 'x-nar-compression)
|
(match compression
|
||||||
(($ <compression> 'gzip level)
|
(($ <compression> 'gzip level)
|
||||||
;; Note: We cannot used chunked encoding here because
|
;; Note: We cannot used chunked encoding here because
|
||||||
;; 'make-gzip-output-port' wants a file port.
|
;; 'make-gzip-output-port' wants a file port.
|
||||||
|
@ -697,11 +697,13 @@ (define (http-write server client response body)
|
||||||
(call-with-new-thread
|
(call-with-new-thread
|
||||||
(lambda ()
|
(lambda ()
|
||||||
(set-thread-name "publish nar")
|
(set-thread-name "publish nar")
|
||||||
(let* ((response (write-response (sans-content-length response)
|
(let* ((compression (assoc-ref (response-headers response)
|
||||||
client))
|
'x-nar-compression))
|
||||||
(port (begin
|
(response (write-response (sans-content-length response)
|
||||||
(force-output client)
|
client))
|
||||||
(nar-response-port response))))
|
(port (begin
|
||||||
|
(force-output client)
|
||||||
|
(nar-response-port response compression))))
|
||||||
;; XXX: Given our ugly workaround for <http://bugs.gnu.org/21093> in
|
;; XXX: Given our ugly workaround for <http://bugs.gnu.org/21093> in
|
||||||
;; 'render-nar', BODY here is just the file name of the store item.
|
;; 'render-nar', BODY here is just the file name of the store item.
|
||||||
;; We call 'write-file' from here because we know that's the only
|
;; We call 'write-file' from here because we know that's the only
|
||||||
|
|
|
@ -111,6 +111,10 @@ (define (wait-for-file file)
|
||||||
(sleep 1)
|
(sleep 1)
|
||||||
(loop (- i 1))))))
|
(loop (- i 1))))))
|
||||||
|
|
||||||
|
(define %gzip-magic-bytes
|
||||||
|
;; Magic bytes of gzip file.
|
||||||
|
#vu8(#x1f #x8b))
|
||||||
|
|
||||||
;; Wait until the two servers are ready.
|
;; Wait until the two servers are ready.
|
||||||
(wait-until-ready 6789)
|
(wait-until-ready 6789)
|
||||||
|
|
||||||
|
@ -213,6 +217,18 @@ (define (wait-for-file file)
|
||||||
(cut restore-file <> temp)))
|
(cut restore-file <> temp)))
|
||||||
(call-with-input-file temp read-string))))
|
(call-with-input-file temp read-string))))
|
||||||
|
|
||||||
|
(unless (zlib-available?)
|
||||||
|
(test-skip 1))
|
||||||
|
(test-equal "/nar/gzip/* is really gzip"
|
||||||
|
%gzip-magic-bytes
|
||||||
|
;; Since 'gzdopen' (aka. 'call-with-gzip-input-port') transparently reads
|
||||||
|
;; uncompressed gzip, the test above doesn't check whether it's actually
|
||||||
|
;; gzip. This is what this test does. See <https://bugs.gnu.org/30184>.
|
||||||
|
(let ((nar (http-get-port
|
||||||
|
(publish-uri
|
||||||
|
(string-append "/nar/gzip/" (basename %item))))))
|
||||||
|
(get-bytevector-n nar (bytevector-length %gzip-magic-bytes))))
|
||||||
|
|
||||||
(unless (zlib-available?)
|
(unless (zlib-available?)
|
||||||
(test-skip 1))
|
(test-skip 1))
|
||||||
(test-equal "/*.narinfo with compression"
|
(test-equal "/*.narinfo with compression"
|
||||||
|
|
Loading…
Reference in a new issue