Skip to content

Practicalli Project Update 2

Clojurists Together Logo

Invested time to understand the changes coming to the Clojure CLI tools and understand the opportunities that Clojure exec (:exec-fn & :exec-args) brings to aliases. These changes provided a catalyst to start redesigning the aliases used in practicalli/clojure-cli-config.

Practicalli Study Groupλ︎

Continuing the Banking on Clojure project, especially around database access. The database schema was refined along with improved approaches to creating database schema, using transactional updates and ensuring connections are closed. The next.jdbc friendly functions were explored and a CRUD approach implemented.

Next steps will be to use Clojure spec for generative testing with the database, add connection pooling and using lifecycle management libraries.

Practicalli WebAppsλ︎

Updated sections on H2 Database and Banking on Clojure

Practicalli Clojureλ︎

Added core principles for writing effective unit tests in Clojure. Included project configuration examples of unit tests for Leiningen and Clojure CLI tools.

Included example configuration for Emacs CIDER test runner and link to the test runner configurations in practicalli/clojure-cli-config.

Clojure CLI Configλ︎

Created a draft guide to changes in the next release of the Clojue CLI tools, to understand the significance of the changes it introduces. The -X flag for executing a function with EDN arguments (hash-map arguments) has already been introduced and the new release depreciates the generic -A alias in favor of -M. In the long term using the -X flag with functions that take a structured argument looks to be an excellent approach.

Started a redesign of practicalli/clojure-cli-config using qualified keywords for alias names. The Library repositories keyword, :mvn/repos, is already qualified, so this redesign brings the aliases in line with that style. The alias keywords are prepended with names to communicate the category of purpose for each alias, e.g. repl, project, env, lib, inspect, build, deploy.

As part of the redesign, the new flags introduced with Clojure CLI tools, -M and -X, are used. The -X flag is the preferred Clojure command line flag to use for the aliases, where the library supports executing a function from the library that takes a hash-map of arguments. Otherwise -M flag replaces -A flag and continues to use clojure.main to call the -main function of the given main namespace.

Add project/check to give detailed report on compilation issues for a project

UPDATE: all aliases in Practicalli CLI Config use fully qualified names.

Practicalli Spacemacsλ︎

Resolved simple bug fixes raised by the community.


Thank you.

🌐 Practical.li Website

Practical.li GitHub Org practicalli-johnny profile

@practicalli@clj.social @practical_li