From bf911deb73f3ab28b6cf8043abe945daeb678a12 Mon Sep 17 00:00:00 2001 From: Carlo Sciolla Date: Mon, 27 Sep 2021 14:35:56 +0200 Subject: [PATCH] Allow person data to be sent through the API Fixes #53 by allowing a `:person` map to be passed through the API call, without breaking any existing API contract --- src/circleci/rollcage/core.clj | 34 +++++++++++++++++----------- test/circleci/rollcage/test_core.clj | 6 +++++ 2 files changed, 27 insertions(+), 13 deletions(-) diff --git a/src/circleci/rollcage/core.clj b/src/circleci/rollcage/core.clj index 02a420a..bf2070b 100644 --- a/src/circleci/rollcage/core.clj +++ b/src/circleci/rollcage/core.clj @@ -31,7 +31,10 @@ :notifier {:name String} :server {:host String :root String - :code_version (s/maybe String)}}}) + :code_version (s/maybe String)}} + (s/optional-key :person) {:id String + (s/optional-key :email) String + (s/optional-key :username) String}}) (defn- deep-merge "Like merge, but merges maps recursively." @@ -167,17 +170,22 @@ level :- String exception :- Throwable url :- (s/maybe String) - custom :- (s/maybe {s/Any s/Any})] + custom :- (s/maybe {s/Any s/Any}) + & [person :- {:id String + (s/optional-key :email) (s/maybe String) + (s/optional-key :username) (s/maybe String)}]] ;; TODO: Pass request parameters through to here - ;; TODO: add person here - (-> client - (dissoc :result-fn :send-fn) - (assoc-in [:data :body :trace_chain] (build-trace exception)) - (assoc-in [:data :level] level) - (assoc-in [:data :timestamp] (timestamp)) - (assoc-in [:data :uuid] (uuid)) - (assoc-in [:data :custom] custom) - (assoc-in [:data :request :url] url))) + (let [item (-> client + (dissoc :result-fn :send-fn) + (assoc-in [:data :body :trace_chain] (build-trace exception)) + (assoc-in [:data :level] level) + (assoc-in [:data :timestamp] (timestamp)) + (assoc-in [:data :uuid] (uuid)) + (assoc-in [:data :custom] custom) + (assoc-in [:data :request :url] url))] + (cond-> item + (some? person) + (assoc :person person)))) (def ^:private rollbar-to-logging "A look-up table to map from Rollbar severity levels to tools.logging levels" @@ -314,10 +322,10 @@ "Report an exception to Rollbar." ([^String level client ^Throwable exception] (notify level client exception {})) - ([^String level {:keys [result-fn send-fn block-fields] :as client} ^Throwable exception {:keys [url params]}] + ([^String level {:keys [result-fn send-fn block-fields] :as client} ^Throwable exception {:keys [url params person]}] (let [params (merge params (throwables/merged-ex-data exception)) scrubbed (scrub params block-fields) - item (make-rollbar client level exception url scrubbed) + item (make-rollbar client level exception url scrubbed person) result (try (send-fn endpoint exception item) (catch Exception e diff --git a/test/circleci/rollcage/test_core.clj b/test/circleci/rollcage/test_core.clj index 73141ff..6688e8c 100644 --- a/test/circleci/rollcage/test_core.clj +++ b/test/circleci/rollcage/test_core.clj @@ -124,6 +124,12 @@ (select-keys (#'client/make-rollbar c "error" (Exception.) nil nil) [:access-token]))))) +(deftest it-can-track-person + (let [c (client/client "access-token" {})] + (is (= {:person {:id "person"}} + (select-keys (#'client/make-rollbar c "error" (Exception.) nil nil {:id "person"}) + [:person]))))) + (deftest ^:integration test-environment-is-setup (is (not (string/blank? (System/getenv "ROLLBAR_ACCESS_TOKEN"))) "You must specify a ROLLBAR_ACCESS_TOKEN with POST credentials"))