;; disfluid, 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 . (define-module (tests authorization-endpoint-get-form) #:use-module (webid-oidc jwk) #:use-module (webid-oidc testing) #:use-module ((webid-oidc parameters) #:prefix p:) #:use-module (web uri) #:use-module (web request) #:use-module (web response) #:use-module (srfi srfi-19) #:use-module (web response) #:use-module (ice-9 optargs) #:use-module (ice-9 receive) #:use-module (webid-oidc server endpoint) #:use-module (webid-oidc server endpoint identity-provider) #:use-module (oop goops) #:duplicates (merge-generics) #:declarative? #t) (with-test-environment "authorization-endpoint-get-form" (lambda () (define subject (string->uri "https://authorization-endpoint-get-form.scm/profile/card#me")) (define password "p4ssw0rd") (define endpoint (make #:subject subject #:encrypted-password (crypt password "$6$some.salt.data") #:key-file (string-append (p:data-home) "/key-file.jwk"))) (receive (response response-body response-meta) (parameterize ((p:current-date 0)) (handle endpoint (build-request (string->uri (format #f "https://authorization-endpoint-get-form.scm/authorize?client_id=~a&redirect_uri=~a" (uri-encode "https://authorization-endpoint-get-form.scm/client/card#app") (uri-encode "https://authorization-endpoint-get-form.scm/client/redirect")))) "")) (unless (eq? (response-code response) 200) (exit 3)) (unless (response-content-type response) (exit 4)) (unless (eq? (car (response-content-type response)) 'application/xhtml+xml) (exit 5)))))