;; disfluid, implementation of the Solid specification ;; Copyright (C) 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 . (define-module (tests hello) #:use-module (webid-oidc server endpoint) #:use-module (webid-oidc server endpoint hello) #:use-module (webid-oidc testing) #:use-module (webid-oidc offloading) #:use-module ((webid-oidc parameters) #:prefix p:) #:use-module (oop goops) #:use-module (web server) #:use-module (web request) #:use-module (web response) #:use-module (web uri) #:use-module (ice-9 match) #:use-module (ice-9 receive) #:use-module (srfi srfi-26) #:use-module (rnrs bytevectors) #:declarative? #t #:duplicates (merge-generics)) (define (drop-sxml-top element) (match element (('*TOP* thing) thing) ((root subtrees ...) `(,root ,@(map drop-sxml-top subtrees))) (x x))) (with-test-environment "hello" (lambda () (define greeter (make )) (with-exception-handler (lambda (exn) (unless (and (web-exception? exn) (equal? (drop-sxml-top (user-message-sxml exn)) `(div (p "You are not authentified."))) (eqv? (web-exception-code exn) 401) (equal? (web-exception-reason-phrase exn) "Unauthorized")) (exit 1) #t)) (lambda () (handle greeter (build-request (string->uri "https://example.com")) #f) (exit 2)) #:unwind? #t) (receive (response response-body response-meta) (handle greeter (build-request (string->uri "https://example.com") #:meta `((user . ,(string->uri "https://example.com/profile/card#me")))) #f) (unless (eqv? (response-code response) 200) (exit 3)))))