0
Fork 0
mirror of https://github.com/penpot/penpot.git synced 2025-01-10 17:00:36 -05:00
penpot/backend/test/uxbox/tests/test_projects.clj
2016-11-20 20:04:52 +01:00

92 lines
3.9 KiB
Clojure

(ns uxbox.tests.test-projects
(:require [clojure.test :as t]
[promesa.core :as p]
[suricatta.core :as sc]
[clj-uuid :as uuid]
[catacumba.testing :refer (with-server)]
[catacumba.serializers :as sz]
[uxbox.db :as db]
[uxbox.frontend :as uft]
[uxbox.services.projects :as uspr]
[uxbox.services.pages :as uspg]
[uxbox.services :as usv]
[uxbox.tests.helpers :as th]))
(t/use-fixtures :each th/database-reset)
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;; Frontend Test
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
(t/deftest test-http-project-list
(with-open [conn (db/connection)]
(let [user (th/create-user conn 1)
proj (uspr/create-project conn {:user (:id user) :name "proj1"})]
(with-server {:handler (uft/routes)}
(let [uri (str th/+base-url+ "/api/projects")
[status data] (th/http-get user uri)]
;; (println "RESPONSE:" status data)
(t/is (= 200 status))
(t/is (= 1 (count data))))))))
(t/deftest test-http-project-create
(with-open [conn (db/connection)]
(let [user (th/create-user conn 1)]
(with-server {:handler (uft/routes)}
(let [uri (str th/+base-url+ "/api/projects")
params {:body {:name "proj1"}}
[status data] (th/http-post user uri params)]
;; (println "RESPONSE:" status data)
(t/is (= 201 status))
(t/is (= (:user data) (:id user)))
(t/is (= (:name data) "proj1")))))))
(t/deftest test-http-project-update
(with-open [conn (db/connection)]
(let [user (th/create-user conn 1)
proj (uspr/create-project conn {:user (:id user) :name "proj1"})]
(with-server {:handler (uft/routes)}
(let [uri (str th/+base-url+ "/api/projects/" (:id proj))
params {:body (assoc proj :name "proj2")}
[status data] (th/http-put user uri params)]
;; (println "RESPONSE:" status data)
(t/is (= 200 status))
(t/is (= (:user data) (:id user)))
(t/is (= (:name data) "proj2")))))))
(t/deftest test-http-project-delete
(with-open [conn (db/connection)]
(let [user (th/create-user conn 1)
proj (uspr/create-project conn {:user (:id user) :name "proj1"})]
(with-server {:handler (uft/routes)}
(let [uri (str th/+base-url+ "/api/projects/" (:id proj))
[status data] (th/http-delete user uri)]
(t/is (= 204 status))
(let [sqlv ["SELECT * FROM projects WHERE \"user\"=? AND deleted_at is null"
(:id user)]
result (sc/fetch conn sqlv)]
(t/is (empty? result))))))))
(t/deftest test-http-project-retrieve-by-share-token
(with-open [conn (db/connection)]
(let [user (th/create-user conn 1)
proj (uspr/create-project conn {:user (:id user) :name "proj1"})
page (uspg/create-page conn {:id (uuid/v4)
:user (:id user)
:project (:id proj)
:version 0
:data "1"
:options "2"
:name "page1"
:width 200
:height 200
:layout "mobil"})
shares (uspr/get-share-tokens-for-project conn (:id proj))]
(with-server {:handler (uft/routes)}
(let [token (:token (first shares))
uri (str th/+base-url+ "/api/projects-by-token/" token)
[status data] (th/http-get user uri)]
;; (println "RESPONSE:" status data)
(t/is (= status 200))
(t/is (vector? (:pages data)))
(t/is (= 1 (count (:pages data)))))))))