Default to value if key is nil

Signed-off-by: Andrea Maria Piana <andrea.maria.piana@gmail.com>
This commit is contained in:
Andrea Maria Piana 2018-06-12 15:09:00 +02:00
parent 61d7cd2a33
commit c66c457bbb
No known key found for this signature in database
GPG Key ID: AA6CCA6DE0E06424
2 changed files with 33 additions and 2 deletions

View File

@ -260,7 +260,8 @@
(let [wnode (get-current-wnode db) (let [wnode (get-current-wnode db)
web3 (:web3 db) web3 (:web3 db)
now-in-s (quot now 1000) now-in-s (quot now 1000)
last-request (get-in db [:account/account :last-request] last-request (or
(get-in db [:account/account :last-request])
(- now-in-s seven-days)) (- now-in-s seven-days))
request-messages-topics (get-request-messages-topics db) request-messages-topics (get-request-messages-topics db)
request-history-topics (get-request-history-topics db)] request-history-topics (get-request-history-topics db)]

View File

@ -66,3 +66,33 @@
(testing "it does not generate a sym key if already present" (testing "it does not generate a sym key if already present"
(is (not (-> (inbox/connect-to-mailserver {:db wnode-with-sym-key-db}) (is (not (-> (inbox/connect-to-mailserver {:db wnode-with-sym-key-db})
:shh/generate-sym-key-from-password))))))) :shh/generate-sym-key-from-password)))))))
(deftest request-messages
(let [db {:network "mainnet"
:mailserver-status :connected
:inbox/wnodes
{:mainnet {"wnodeid" {:address "wnode-address"
:sym-key-id "something"
:password "wnode-password"}}}
:account/account
{:settings {:wnode {:mainnet "wnodeid"}}
:networks {"mainnet" {:config {:NetworkId 1}}}}}
cofx {:db db :now 1000000000}]
(testing "inbox is ready"
(testing "last-request is set"
(let [cofx-with-last-request (assoc-in cofx [:db :account/account :last-request] 2)
actual (inbox/request-messages cofx-with-last-request)]
(testing "it uses last request"
(is (= 2 (get-in actual [::inbox/request-messages :from]))))))
(testing "last-request is not set"
(let [actual (inbox/request-messages cofx)]
(testing "it defaults to the last 7 days"
(is (= 395200 (get-in actual [::inbox/request-messages :from]))))))
(testing "last-request is nil"
(let [cofx-with-last-request (assoc-in cofx [:db :account/account :last-request] nil)
actual (inbox/request-messages cofx-with-last-request)]
(testing "it defaults to the last 7 days"
(is (= 395200 (get-in actual [::inbox/request-messages :from])))))))
(testing "inbox is not ready"
(testing "it does not do anything"
(is (nil? (inbox/request-messages {})))))))