doc: clarify semantic versioning policy (#688)

The oonimkall package is only public for technical reasons. We
cannot use `go mobile` on a private package. We consider oonimkall
our private interface to our mobile apps, thus we reserve the
right to change its API without bumping the major number.

We'll bump the major number in case of breaking changes in the
cmd/ooniprobe CLI interface, or in case of other major improvements
that significantly modify cmd/ooniprobe.
This commit is contained in:
Simone Basso 2022-02-09 14:43:03 +01:00 committed by GitHub
parent eed007a5d0
commit 872971ed8c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 17 additions and 0 deletions

View File

@ -22,6 +22,15 @@ while most others are top-level. This is part of a long-standing refactoring sta
when we merged https://github.com/ooni/probe-engine into this repository. We'll slowly when we merged https://github.com/ooni/probe-engine into this repository. We'll slowly
ensure that all packages inside `engine` are moved out of it and inside `internal`. ensure that all packages inside `engine` are moved out of it and inside `internal`.
## Semantic versioning policy
The mobile library is a public package for technical reasons. Go mobile tools require
a public package to build from. Yet, we don't consider API breakages happening in
such a package to be sufficient to bump our major version number. For us, the mobile
library is just a mean to implement OONI Probe Android and OONI Probe iOS. We'll
only bump the major version number if we implement any set of breaking changes of
the `./cmd/ooniprobe`'s CLI.
## License ## License
``` ```

View File

@ -9,6 +9,14 @@
// reimplementation of the mkall API implemented by Measurement Kit // reimplementation of the mkall API implemented by Measurement Kit
// in, e.g., https://github.com/measurement-kit/mkall-ios. // in, e.g., https://github.com/measurement-kit/mkall-ios.
// //
// Semantic versioning policy
//
// This package is public for technical reasons. We cannot use `go
// mobile` on a private package. Yet, we are not going to bump this
// repository's major number in case we change oonimkall's API. We
// consider this package our private API for interfacing with our
// mobile applications for Android and iOS.
//
// Task API // Task API
// //
// The basic tenet of the task API is that you define an experiment // The basic tenet of the task API is that you define an experiment