Skip to content

Commit

Permalink
Fix inclusion of explicitly added profiles in jar
Browse files Browse the repository at this point in the history
  • Loading branch information
hugoduncan committed Sep 25, 2014
1 parent 1908500 commit bb0b132
Show file tree
Hide file tree
Showing 2 changed files with 17 additions and 1 deletion.
7 changes: 6 additions & 1 deletion src/leiningen/jar.clj
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@
[leiningen.core.eval :as eval]
[leiningen.core.main :as main]
[bultitude.core :as b]
[clojure.set :as set]
[clojure.string :as string]
[clojure.java.io :as io])
(:import (java.util.jar Manifest JarEntry JarOutputStream)
Expand Down Expand Up @@ -311,7 +312,11 @@ With an argument, the jar will be built with an alternate main."
([project main]
(when (:auto-clean project true)
(clean/clean project))
(let [provided-profiles (project/pom-scope-profiles project :provided)
(let [scoped-profiles (set (project/pom-scope-profiles project :provided))
default-profiles (set (project/expand-profile project :default))
provided-profiles (remove
(set/difference default-profiles scoped-profiles)
(-> project meta :included-profiles))
project (preprocess-project project main)]
(merge (main-jar project provided-profiles main)
(classifier-jars project provided-profiles))))
Expand Down
11 changes: 11 additions & 0 deletions test/leiningen/test/jar.clj
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
(ns leiningen.test.jar
(:require [clojure.java.io :as io]
[leiningen.core.main :as main]
[leiningen.core.project :as project]
[leiningen.core.utils :refer [platform-nullsink]]
[leiningen.test.helper :as helper])
(:use [clojure.test]
Expand Down Expand Up @@ -37,6 +38,16 @@
(is (entry-names "nested/dir/"))
(is (not (some #(.startsWith % "/") entry-names))))))

(deftest test-profile-added-to-jar
(with-out-str
(let [project (-> helper/with-resources-project
(project/add-profiles
{:test-jar {:resource-paths ^:replace []}})
(project/merge-profiles [:test-jar]))
jar (first (vals (jar project)))
entry-names (set (helper/walkzip jar #(.getName %)))]
(is (not (entry-names "nested/dir/sample.txt"))))))

(deftest test-no-aot-jar-succeeds
(with-out-str
(is (jar helper/sample-no-aot-project))))
Expand Down

0 comments on commit bb0b132

Please sign in to comment.