Skip to content
This repository has been archived by the owner on Nov 20, 2024. It is now read-only.

Commit

Permalink
[GH-1697] Deploy WFL v0.20.2 to dev, prod, and aou if the fix for GH-…
Browse files Browse the repository at this point in the history
…1695 works. (#627)

* [GH-1695] Fix the "increment BAM version in Clio" again. (#626)
* Always return the BAM record inserted to Clio (`bam` or `again`).
* Write the BAM record inserted to Clio into clio-bam-record.json.
* clojure -M:format
* Consistency.
* Update CHANGELOG.md and version.
  • Loading branch information
tbl3rd authored Sep 29, 2022
1 parent 995bb12 commit b81e6bf
Show file tree
Hide file tree
Showing 4 changed files with 50 additions and 30 deletions.
3 changes: 3 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,3 +1,6 @@
# Release 0.20.2
- [GH-1695] Fix the "increment BAM version in Clio" again. ([#626](https://github.com/broadinstitute/wfl/pull/626))

# Release 0.20.1
- [GH-1691] Fix the SG/GDC increment the add_bam version in Clio hack. ([#623](https://github.com/broadinstitute/wfl/pull/623))

Expand Down
27 changes: 15 additions & 12 deletions api/src/wfl/module/sg.clj
Original file line number Diff line number Diff line change
Expand Up @@ -176,19 +176,22 @@
(str/ends-with? body clio-force=true-error-message-ends))))

(defn ^:private clio-add-bam
"Add `bam` to `clio`, and maybe retry once with a new :version."
"Add `bam` to `clio`, and try `again` with maybe a new `:version`.
Always return the BAM record inserted to Clio (`bam` or `again`)."
[clio bam]
(try (clio/add-bam clio bam)
bam
(catch Throwable x
(log/error {:bam bam :x x})
(clio/add-bam
clio (if (hack-try-increment-version-in-clio-add-bam? x)
(-> bam (select-keys clio-key-no-version)
(->> (clio/query-bam clio)
(sort-by :version)
last :version inc
(assoc bam :version)))
bam)))))
(let [again (if (hack-try-increment-version-in-clio-add-bam? x)
(-> bam (select-keys clio-key-no-version)
(->> (clio/query-bam clio)
(sort-by :version)
last :version inc
(assoc bam :version)))
bam)]
(clio/add-bam clio again)
again))))

(defn ^:private maybe-update-clio-and-write-final-files
"Maybe update `clio-url` with `final` and write files and `metadata`."
Expand All @@ -199,9 +202,9 @@
bam (-> cram (merge final) (dissoc :contamination))
contam (:contamination final)
suffix (last (str/split contam #"/"))
folder (str (util/unsuffix contam suffix))]
(clio-add-bam clio-url bam)
(-> bam
folder (str (util/unsuffix contam suffix))
record (clio-add-bam clio-url bam)]
(-> record
(json/write-str :escape-slash false)
(gcs/upload-content (str folder "clio-bam-record.json")))
(-> metadata
Expand Down
48 changes: 31 additions & 17 deletions api/test/wfl/integration/modules/sg_test.clj
Original file line number Diff line number Diff line change
Expand Up @@ -178,8 +178,8 @@
(is false))

(defn ^:private mock-clio-query-bam-found
"Return a `_clio` BAM record with metadata `_md`."
[_clio {:keys [bam_path] :as _md}]
"Return a `_clio` BAM record with metadata `_query`."
[_clio {:keys [bam_path] :as _query}]
[{:bai_path (str/replace bam_path ".bam" ".bai")
:bam_path bam_path
:billing_project "hornet-nest"
Expand All @@ -194,13 +194,18 @@
:version 23}])

(defn ^:private mock-clio-query-bam-missing
"Return an empty `_clio` response for query metadata `_md`."
[_clio _md]
[])
"Return an empty `_clio` response for a `bam_path` `query`.
Return a key matching `mock-clio-query-bam-found`."
[_clio {:keys [bam_path] :as _query}]
(if bam_path [] [{:data_type "WGS"
:location "GCP"
:project "G96830"
:sample_alias "NA12878"
:version 23}]))

(defn ^:private mock-clio-query-cram-found
"Return a `_clio` CRAM record with metadata `_md`."
[_clio {:keys [cram_path] :as _md}]
"Return a `_clio` CRAM record with metadata `_query`."
[_clio {:keys [cram_path] :as _query}]
[{:billing_project "hornet-nest"
:crai_path (str cram_path ".crai")
:cram_md5 "0cfd2e0890f45e5f836b7a82edb3776b"
Expand Down Expand Up @@ -296,18 +301,27 @@
(is false))

(defn mock-gcs-upload-content
"Mock uploading `content` to `url`."
"Mock uploading `content` to `url`. Return `content` as EDN."
[content url]
(letfn [(parse [url] (drop-last (str/split url #"/")))
(tail? [end] (str/ends-with? url end))]
(let [md [:outputs :GDCWholeGenomeSomaticSingleSample.contamination]
ok? (partial = (parse url))
edn (util/parse-json content)]
(let [md [:outputs :GDCWholeGenomeSomaticSingleSample.contamination]
ok? (partial = (parse url))
result (util/parse-json content)]
(is (cond (tail? "/clio-bam-record.json")
(ok? (parse (:bai_path edn)))
(ok? (parse (:bai_path result)))
(tail? "/cromwell-metadata.json")
(ok? (parse (get-in edn md)))
:else false)))))
(ok? (parse (get-in result md)))
:else false))
result)))

(defn mock-gcs-upload-content-force=true
"Mock uploading `content` to `url` and test that `version` is 24 in JSON."
[content url]
(let [{:keys [id version]} (mock-gcs-upload-content content url)]
(is (cond version (== 24 version)
id true
:else false))))

(defn ^:private test-clio-updates
"Assert that Clio is updated correctly."
Expand Down Expand Up @@ -350,12 +364,12 @@
(deftest test-handle-add-bam-force=true-mocked
(testing "Retry add-bam when a mock Clio suggests force=true."
(with-redefs [clio/add-bam mock-add-bam-suggest-force=true
clio/query-bam mock-clio-query-bam-found
clio/query-bam mock-clio-query-bam-missing
clio/query-cram mock-clio-query-cram-found
cromwell/metadata mock-cromwell-metadata-succeeded
cromwell/query mock-cromwell-query-succeeded
cromwell/submit-workflows mock-cromwell-submit-workflows
gcs/upload-content mock-gcs-upload-content]
gcs/upload-content mock-gcs-upload-content-force=true]
(test-clio-updates)))
(testing "Do not retry when a mock Clio rejects add-bam for another reason."
(with-redefs [clio/add-bam mock-add-bam-throw-something-else
Expand All @@ -364,7 +378,7 @@
cromwell/metadata mock-cromwell-metadata-succeeded
cromwell/query mock-cromwell-query-succeeded
cromwell/submit-workflows mock-cromwell-submit-workflows
gcs/upload-content mock-gcs-upload-content]
gcs/upload-content mock-gcs-upload-content-force=true]
(is (thrown-with-msg? Exception #"clj-http: status 500" (test-clio-updates))))))

(deftest test-handle-add-bam-force=true-for-real
Expand Down
2 changes: 1 addition & 1 deletion version
Original file line number Diff line number Diff line change
@@ -1 +1 @@
0.20.1
0.20.2

0 comments on commit b81e6bf

Please sign in to comment.