From 1bcbf65cfaf500f1f4169351378da54aee17584e Mon Sep 17 00:00:00 2001 From: "antoine.gonzalez" Date: Thu, 30 Nov 2023 17:38:55 +0100 Subject: [PATCH] Add development doc #130 --- docs/dev/index.md | 9 ----- docs/develop.md | 84 ++++++++++++++++++++++++++++++++++++++++++++++ docs/index.md | 2 +- docs/quickstart.md | 5 +-- 4 files changed, 86 insertions(+), 14 deletions(-) delete mode 100644 docs/dev/index.md create mode 100644 docs/develop.md diff --git a/docs/dev/index.md b/docs/dev/index.md deleted file mode 100644 index de061e09..00000000 --- a/docs/dev/index.md +++ /dev/null @@ -1,9 +0,0 @@ -# Development - -:::{admonition} WIP -:class: attention - -This documentation is a work in progress. -::: - -This page is the index of the developer's guide to contributing. \ No newline at end of file diff --git a/docs/develop.md b/docs/develop.md new file mode 100644 index 00000000..6e211e9e --- /dev/null +++ b/docs/develop.md @@ -0,0 +1,84 @@ +# Development + +:::{admonition} WIP +:class: attention + +This documentation is a work in progress. +::: + +:::{admonition} TODO +:class: attention + +* Edit source links to redirect to the API reference or guides. +::: + +This page will summarize how to modify enioka Scan, whether it is to contribute to the project or +for personal use. + +## Developing for Android + +In order to start developing and testing the library: +- Have Android Studio installed and open the project with it +- Connect a compatible android device via USB, it should then show up in Android Studio's device + manager +- Run the demo app with the android device selected. The app includes the library and all available + providers + +In case the android device is not detected by Android Studio: +- Make sure the device is in developer mode and has USB Debugging enabled +- Make sure the USB cable supports data transfer (some cables only support charging) + +## Adding to the ReadTheDocs documentation + +To test documentation changes locally, you need to install Sphinx and other dependencies. Using +python 3, you can run `pip install -r ./docs/requirements.txt` in your virtual environment. + +In order to build the documentation, run `sphinx-build -a ./docs `. + +To view the generated documentation, use the url `file:///index.html` in your web +browser. + +## Adding another SDK / Scanner provider + +A scanner SDK contains at least a [`Scanner`][scanner-api] implementation (interfacing between the +code and the device) and a [`ScannerProvider`][scanner-provider-api] implementation (handling +scanner creation and device compatibility checks). + +In order for a new scanner SDK to be found by the library, the +[`ScannerProvider`][scanner-provider-api] implementation needs to be declared as a service in its +`AndroidManifest.xml` with an intent-filter containing the action `com.enioka.scan.PROVIDE_SCANNER`. + +The associated Java class does not need to extend Android's `Service` class(the +`tools:ignore="Instantiatable"` attribute may be added to the service in the manifest), +but it must provide a public default constructor as it will be instantiated using `Class.getName()`. + +:::{hint} + +See the [Mock SDK][mock-sdk] for an example of addon SDK. +::: + +## Library tests + +While not every aspect of the code may be easily tested, some parts can and should be. For example, +parsers and translation methods used to convert enioka Scan API methods to device-specific commands +should be unit-tested to ensure payloads are properly handled. + +The repository contains GitHub Action pipelines to build the library and launch both JUnit and +Android Instrumented tests for both Android API levels 19 (the minimum supported version) and 28 +(the target version). + +## Release process + +Once enough features or fixes are merged into `master`, a new version tag will be pushed by a +repository owner/maintainer. This will trigger a GitHub Action workflow to create a release with an +artefact of the core library, and will upload all artefacts to Maven Central. + +:::{warning} + +The release tag ***must*** be pushed from the CLI, as a tag or release created from the +GitHub web UI will fail to trigger the workflow. +::: + +[mock-sdk]: https://github.com/enioka-Haute-Couture/enioka_scan/blob/master/enioka_scan_mock +[scanner-api]: https://github.com/enioka-Haute-Couture/enioka_scan/blob/master/enioka_scan/src/main/java/com/enioka/scanner/api/Scanner.java +[scanner-provider-api]: https://github.com/enioka-Haute-Couture/enioka_scan/blob/master/enioka_scan/src/main/java/com/enioka/scanner/api/ScannerProvider.java diff --git a/docs/index.md b/docs/index.md index 1c516f47..3739e419 100644 --- a/docs/index.md +++ b/docs/index.md @@ -35,5 +35,5 @@ quickstart dependencies guides/index api/index -dev/index +develop ::: \ No newline at end of file diff --git a/docs/quickstart.md b/docs/quickstart.md index 7a766625..25d2f1c0 100644 --- a/docs/quickstart.md +++ b/docs/quickstart.md @@ -9,8 +9,7 @@ This documentation is a work in progress. :::{admonition} TODO :class: attention -* Edit source links to redirect to the API reference. Maybe a `guides` section could help too. -* Simplify the quick start, currently too much text and too many parts +* Edit source links to redirect to the API reference or guides. ::: This guide will show you the minimum required steps to include **enioka Scan** in your application. @@ -193,10 +192,8 @@ scanning. The provided Camera activity will display a target rectangle, which can be moved or tapped to change or refresh the autofocus area. -[mock-sdk]: https://github.com/enioka-Haute-Couture/enioka_scan/blob/master/enioka_scan_mock [scanner-api]: https://github.com/enioka-Haute-Couture/enioka_scan/blob/master/enioka_scan/src/main/java/com/enioka/scanner/api/Scanner.java [scanner-client]: https://github.com/enioka-Haute-Couture/enioka_scan/blob/master/enioka_scan/src/main/java/com/enioka/scanner/service/ScannerClient.java [scanner-compat-activity]: https://github.com/enioka-Haute-Couture/enioka_scan/blob/master/enioka_scan/src/main/java/com/enioka/scanner/activities/ScannerCompatActivity.java -[scanner-provider-api]: https://github.com/enioka-Haute-Couture/enioka_scan/blob/master/enioka_scan/src/main/java/com/enioka/scanner/api/ScannerProvider.java [scanner-search-options]: https://github.com/enioka-Haute-Couture/enioka_scan/blob/master/enioka_scan/src/main/java/com/enioka/scanner/api/ScannerSearchOptions.java [scanner-service-api]: https://github.com/enioka-Haute-Couture/enioka_scan/blob/master/enioka_scan/src/main/java/com/enioka/scanner/service/ScannerServiceApi.java