;; webid-oidc, implementation of the Solid specification ;; Copyright (C) 2020, 2021 Vivien Kraus ;; This program is free software: you can redistribute it and/or modify ;; it under the terms of the GNU Affero General Public License as ;; published by the Free Software Foundation, either version 3 of the ;; License, or (at your option) any later version. ;; This program is distributed in the hope that it will be useful, ;; but WITHOUT ANY WARRANTY; without even the implied warranty of ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ;; GNU Affero General Public License for more details. ;; You should have received a copy of the GNU Affero General Public License ;; along with this program. If not, see . (use-modules (webid-oidc server precondition) (webid-oidc errors) (webid-oidc testing) (web http) (web request) (web response) (web uri) (ice-9 receive) (rnrs bytevectors)) (with-test-environment "preconditions" (lambda () (check-precondition "/whatever" #f #f #f) (check-precondition "/whatever" #f #f "etag") (check-precondition "/whatever" '* #f "etag") (check-precondition "/whatever" '* '() "etag") (check-precondition "/whatever" #f '("other") "etag") (check-precondition "/whatever" '("one" "etag" "or" "another") '() "etag") (with-exception-handler (lambda (error) (unless (precondition-failed? error) (exit 1))) (lambda () (check-precondition "/whatever" '("etag") '("etag") "etag")) #:unwind? #t #:unwind-for-type &precondition-failed) (with-exception-handler (lambda (error) (unless (precondition-failed? error) (exit 1))) (lambda () (check-precondition "/whatever" '("etag") '* "etag")) #:unwind? #t #:unwind-for-type &precondition-failed) (with-exception-handler (lambda (error) (unless (precondition-failed? error) (exit 1))) (lambda () (check-precondition "/whatever" '("nope") '() "etag")) #:unwind? #t #:unwind-for-type &precondition-failed) (with-exception-handler (lambda (error) (unless (precondition-failed? error) (exit 1))) (lambda () (check-precondition "/whatever" '("nope") '() "etag")) #:unwind? #t #:unwind-for-type &precondition-failed) (with-exception-handler (lambda (error) (unless (precondition-failed? error) (exit 1))) (lambda () (check-precondition "/whatever" '* #f #f)) #:unwind? #t #:unwind-for-type &precondition-failed) (with-exception-handler (lambda (error) (unless (precondition-failed? error) (exit 1))) (lambda () (check-precondition "/whatever" '() #f #f)) #:unwind? #t #:unwind-for-type &precondition-failed) (check-precondition "/whatever" #f '* #f) (check-precondition "/whatever" #f '() #f)))