Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/borkdude/api-diff
Print API diffs between library versions
https://github.com/borkdude/api-diff
Last synced: 3 months ago
JSON representation
Print API diffs between library versions
- Host: GitHub
- URL: https://github.com/borkdude/api-diff
- Owner: borkdude
- Created: 2021-09-30T18:57:35.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2021-10-25T18:25:00.000Z (about 3 years ago)
- Last Synced: 2024-10-04T11:59:25.923Z (3 months ago)
- Language: Clojure
- Size: 24.4 KB
- Stars: 59
- Watchers: 4
- Forks: 2
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- stars - borkdude/api-diff - Print API diffs between library versions (⭐️59) (Clojure)
- stars - borkdude/api-diff - Print API diffs between library versions (⭐️59) (Clojure)
README
# api-diff
This tool prints the diff of breaking changes between two Clojure library
versions.## Status - Alpha
Api-diff is in the early stages of development - any interfaces can be expected to change.
We encourage you to try the tool out and greatly appreciate any feedback you might share.
Raise an issue or drop by and chat in the [Clojurians Slack #clj-kondo channel](https://clojurians.slack.com/messages/CHY97NXE2).
## Installation
To invoke via `-M:api-diff` add this alias to your `deps.edn`:
``` clojure
{:aliases
{:api-diff
{:replace-deps
{borkdude/api-diff {:git/url "https://github.com/borkdude/api-diff"
:git/sha ""}}
:main-opts ["-m" "borkdude.api-diff"]}}}
```Or install as tool:
```
clj -Ttools install com.github.borkdude/api-diff '{:git/tag ""}' :as api-diff
```# Usage
Arguments for comparing two mvn libs:
- `:lib`: fully qualified symbol
- `:v1`: the older version as mvn lib
- `:v2:` the newer version as mvn libArguments for comparing two directories:
- `:path1`: the file or directory with older
- `:path2`: the file or directory with newerThis tool currently only prints breaking changes: removed vars or removed
arities. To see what was added in a newer version, just swap `:v1` and `:v2`
(for now):```
clj_kondo/core.clj:205:1: error: clj-kondo.core/resolve-config was removed.
clj_kondo/core.clj:213:1: error: clj-kondo.core/config-hash was removed.
clj_kondo/impl/analyzer.clj:1473:1: error: clj-kondo.impl.analyzer/analyze-ns-unmap was removed.
```Comparing two jars locally:
```
clj -M:api-diff :path1 ./my-jar-v1.2.jar :path2 ./my-jar-v1.3.jar
```or via tool usage:
```
$ clj -Tapi-diff api-diff :lib clj-kondo/clj-kondo :v1 '"2021.09.25"' :v2 '"2021.09.15"'
```Optional exclusions:
- `:exclude-meta`: exclude namespaces and vars with specified metadata keyword, repeat for multiple
Some libraries use `:no-doc` metadata to mark which namespaces and vars are not part of their documented public API.
Use `:exclude-meta` to diff only the public API of these libraries:```
$ clojure -M:api-diff :lib zprint/zprint :v1 0.4.16 :v2 1.1.2 :exclude-meta no-doc
zprint/rewrite.cljc:29:1: warning: zprint.rewrite/prewalk now has meta [:no-doc].
zprint/rewrite.cljc:44:1: warning: zprint.rewrite/get-sortable now has meta [:no-doc].
zprint/rewrite.cljc:54:1: warning: zprint.rewrite/sort-val now has meta [:no-doc].
zprint/rewrite.cljc:90:1: warning: zprint.rewrite/sort-down now has meta [:no-doc].
```Other libraries use `:skip-wiki`. Let's first compare 2 versions of spec.alpha with no exclusions:
```
$ clojure -M:api-diff :lib org.clojure/spec.alpha :v1 0.1.108 :v2 0.2.194
clojure/spec/alpha.clj:348:1: error: clojure.spec.alpha/map-spec was removed.
clojure/spec/alpha.clj:1360:1: error: clojure.spec.alpha/amp-impl arity 3 was removed.
```
Now let's repeat the run with the knowledge that this library use metadata to exclude vars from its public API:
```
$ clojure -M:api-diff :lib org.clojure/spec.alpha :v1 0.1.108 :v2 0.2.194 \
:exclude-meta skip-wiki :exclude-meta no-doc
clojure/spec/alpha.clj:348:1: error: clojure.spec.alpha/map-spec was removed.
```
Now we only see the relevant changes to the public API.## How it works
To discover APIs, api-diff uses [clj-kondo's data analysis feature](https://github.com/clj-kondo/clj-kondo/tree/master/analysis).
For reasons of safety and speed, clj-kondo uses static analysis.
This means it reads, but does not run, source code.There are some libraries generate their APIs at runtime.
Clj-kondo has built-in support to apply the effect of [potemkin import-vars](https://github.com/clj-commons/potemkin#import-vars) and can be configured to apply the effect of other macros that manipulate APIs at runtime.