mirror of
https://github.com/penpot/penpot.git
synced 2025-01-10 08:50:57 -05:00
82 lines
No EOL
2.9 KiB
Clojure
82 lines
No EOL
2.9 KiB
Clojure
;; This Source Code Form is subject to the terms of the Mozilla Public
|
|
;; License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
;; file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
;;
|
|
;; Copyright (c) KALEIDOS INC
|
|
|
|
(ns frontend-tests.basic-shapes-test
|
|
(:require
|
|
[app.common.test-helpers.files :as cthf]
|
|
[app.common.test-helpers.ids-map :as cthi]
|
|
[app.common.test-helpers.shapes :as cths]
|
|
[app.main.data.workspace.colors :as dc]
|
|
[app.main.data.workspace.shapes :as dwsh]
|
|
[cljs.test :as t :include-macros true]
|
|
[frontend-tests.helpers.state :as ths]))
|
|
|
|
(t/deftest test-update-shape
|
|
(t/async
|
|
done
|
|
(let [;; ==== Setup
|
|
store
|
|
(ths/setup-store
|
|
(-> (cthf/sample-file :file1 :page-label :page1)
|
|
(cths/add-sample-shape :shape1)))
|
|
|
|
;; ==== Action
|
|
events
|
|
[(dwsh/update-shapes [(cthi/id :shape1)]
|
|
#(assoc % :fills
|
|
(cths/sample-fills-color :fill-color
|
|
"#fabada")))]]
|
|
|
|
(ths/run-store
|
|
store done events
|
|
(fn [new-state]
|
|
(let [;; ==== Get
|
|
shape1' (get-in new-state [:workspace-data
|
|
:pages-index
|
|
(cthi/id :page1)
|
|
:objects
|
|
(cthi/id :shape1)])
|
|
fills' (:fills shape1')
|
|
fill' (first fills')]
|
|
|
|
;; ==== Check
|
|
(t/is (some? shape1'))
|
|
(t/is (= (count fills') 1))
|
|
(t/is (= (:fill-color fill') "#fabada"))
|
|
(t/is (= (:fill-opacity fill') 1))))))))
|
|
|
|
(t/deftest test-update-stroke
|
|
;; Old shapes without stroke-alignment are rendered as if it is centered
|
|
(t/async
|
|
done
|
|
(let [;; ==== Setup
|
|
store
|
|
(ths/setup-store
|
|
(-> (cthf/sample-file :file1 :page-label :page1)
|
|
(cths/add-sample-shape :shape1 :strokes [{:stroke-color "#000000"
|
|
:stroke-opacity 1
|
|
:stroke-width 2}])))
|
|
|
|
;; ==== Action
|
|
events
|
|
[(dc/change-stroke #{(cthi/id :shape1)} {:color "#FABADA"} 0)]]
|
|
|
|
(ths/run-store
|
|
store done events
|
|
(fn [new-state]
|
|
(let [;; ==== Get
|
|
shape1' (get-in new-state [:workspace-data
|
|
:pages-index
|
|
(cthi/id :page1)
|
|
:objects
|
|
(cthi/id :shape1)])
|
|
stroke' (-> (:strokes shape1')
|
|
first)]
|
|
|
|
;; ==== Check
|
|
(println stroke')
|
|
(t/is (some? shape1'))
|
|
(t/is (= (:stroke-alignment stroke') :center)))))))) |