;; 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 client-manifest) (webid-oidc testing) (webid-oidc errors) (web uri) (srfi srfi-19) (web response)) (with-test-environment "client-manifest-public" (lambda () (define mf (get-client-manifest (string->uri "http://www.w3.org/ns/solid/terms#PublicOidcClient") #:http-get (lambda args (exit 1)))) (define id (client-manifest-client-id mf)) (unless (equal? id (string->uri "http://www.w3.org/ns/solid/terms#PublicOidcClient")) (exit 2)) (unless (client-manifest-check-redirect-uri mf "https://example.com") (exit 3)) (with-exception-handler (lambda (error) (unless ((record-predicate &cannot-serve-public-manifest) error) (exit 4))) (lambda () (serve-client-manifest (time-utc->date (make-time time-utc 0 0)) mf) (exit 5)) #:unwind? #t #:unwind-for-type &cannot-serve-public-manifest)))