# Day 7 – Create and run your first project
These days, most Clojurists use Leiningen to build and manage their projects.
# Instalation
Leiningen is the easiest way to use Clojure with a focus on project automation and declarative configuration. To see how to install (opens new window) and configure Leiningen, go to the official documentation and follow the necessary steps.
# Creating a new project
After the installation finishes, run to the terminal and create your first project with the command:
lein new app my-first-clojure-app
Access the directory.
cd my-first-clojure-app
When listing directory files, you should have output similar to this.
.
├── CHANGELOG.md
├── LICENSE
├── README.md
├── doc
│ └── intro.md
├── project.clj
├── resources
├── src
│ └── my_first_clojure_app
│ └── core.clj
└── test
└── my_first_clojure_app
└── core_test.clj
6 directories, 7 files
The project.clj
file is the file that holds the project settings and specifies the dependencies for the project.
(defproject my-first-clojure-app "0.1.0-SNAPSHOT"
:description "FIXME: write description"
:url "http://example.com/FIXME"
:license {:name "EPL-2.0 OR GPL-2.0-or-later WITH Classpath-exception-2.0"
:url "https://www.eclipse.org/legal/epl-2.0/"}
:dependencies [[org.clojure/clojure "1.10.0"]]
:main ^:skip-aot my-first-clojure-app.core
:target-path "target/%s"
:profiles {:uberjar {:aot :all}})
In src/my_first_clojure_app/core.clj
is where you will write your Clojure code for a while or until you need to separate the application into other namespaces.
As the name suggests, tests
is where you will store all test files for their respective resources.
And finally, resources
store's assets as images, etc.
# Run the project
Before running the project, open the file src/my_first_clojure_app/core.clj
and change the entry point of your program.
(ns my-first-clojure-app.core
(:gen-class))
(defn -main
"I don't do a whole lot ... yet."
[& args]
(println "This is the first app in Clojure!"))
Then run the project with the command:
lein run
This should be the output: This is the first app in Clojure!
Using lein run
to test your development code is great and helps you save a lot of time without compiling a file.
But there are cases where you will need to compile your program to run on other platforms that do not have Leiningen or some production code. To compilate the project, you can simply use the following command:
lein uberjar
When you run the command, you will be presented with your Clojure program that can be run on any platform.
If all went well, you should have the following console output.
Created .../my-first-clojure-app/java -jar target/uberjar/my-first-clojure-app-0.1.0-SNAPSHOT-standalone.jar
Voce pode executar o programa gerado como faria com qualquer programa em Java.
java -jar target/uberjar/my-first-clojure-app-0.1.0-SNAPSHOT-standalone.ja
Wow, congratulations! You now have all the basic details you need to build, run, and distribute (very) basic Clojure programs.
# Tests
Leiningen provides a more automated and simple way to run the tests in your application.
lein test
That will generate the following output.
lein test my-first-clojure-app.core-test
lein test :only my-first-clojure-app.core-test/a-test
FAIL in (a-test) (core_test.clj:7)
FIXME, I fail.
expected: (= 0 1)
actual: (not (= 0 1))
Ran 1 tests containing 1 assertions.
1 failures, 0 errors.
Tests failed.
Go to the test/my_first_clojure_app/core_test.clj
file and change the test.
(deftest a-test
(testing "Fixed! It works now."
(is (= 1 1))))
Now, running again for lein test
will get the following output.
lein test my-first-clojure-app.core-test
Ran 1 tests containing 1 assertions.
0 failures, 0 errors.
# Test your knowledge
- Create a new app using
lein
. - Use o conhecimento que voce adquiriu nos dias anteriores para criar novas funcionalidades ao seu programa.
- Compile your program with
lein uberjar
and send it to a friend to execute. - Build your imagination and keep on studying.
# License
This project is licensed under the MIT License.