Skip to content

RelevanceAI/RelevanceAI-readme-docs

Repository files navigation

RelevanceAI-readme-docs

This repository updates RelevanceAI's ReadMe Documentation here.

🧠 Documentation

πŸ› οΈ Requirements

🧰 OS Tested

  • Linux (Ubuntu 18.04.6 LTS (Bionic Beaver) Debian)

πŸ‘©πŸ»β€πŸ’» Getting Started with this ReadMe sync repo

The main branch is the live branch in ReadMe. By following instructions below, you will be able to preview/create any given version of the docs at any one time.

❯ tree -L 1
.
β”œβ”€β”€ assets                      ## Assets for this README
β”œβ”€β”€ colab_requirements.txt      ## Colab env reqs
β”œβ”€β”€ config                      ## Docs/ReadMe files
β”œβ”€β”€ docs                        ## Generated docs files
β”œβ”€β”€ docs_template               ## Templates and all resources for auto-generation
β”œβ”€β”€ examples                    ## For testing notebook tests
β”œβ”€β”€ export_md                   ## Ignore: Readme Markdown exports
β”œβ”€β”€ migration                   ## Ignore: instructions for the initial migration
β”œβ”€β”€ package.json                ## NPM deps
β”œβ”€β”€ package-lock.json           ## NPM deps lock
β”œβ”€β”€ rdmd.md                     ## Rdmd cheatsheet
β”œβ”€β”€ rdme.md                     ## Rdme cheatsheet
β”œβ”€β”€ README.md
β”œβ”€β”€ requirements.txt            ## Python reqs
β”œβ”€β”€ sync                        ## Automation scripts to build and sync docs
└── __version__
  1. Install dependencies if first time; note, this repo has both Python and NPM deps

    ❯ git clone git@github.com:RelevanceAI/RelevanceAI-readme-docs.git
    ❯ python -m venv .venv                 # Create new Python venv
    ❯ source .venv/bin/activate            # Activate new venv
    ❯ make install
  2. Create a new branch for the ReadMe version you'd like to create if not already auto-created upon SDK release eg. v1.0.0

    • Branch off the latest version that you'd like to fork from (if it is not main)
    ❯ git checkout -b v1.0.0
    ❯ git checkout -b v1.0.0-fix-typo
  3. Make your desired changes to the relevant Markdown/notebooks in docs_templates. Sync your changes.

These are templates because all the files and notebooks in docs_templates are written in a templated language and are synced with code snippets.

πŸ‘©πŸ»β€πŸ’» Adding a new guide

  1. To add new assets (i):
    • Add new assets to the corresponding _assets folder in docs_template.
    • Update asset links in md files to point to corresponding path.
  2. To add new notebooks:
    • Add new notebooks to the corresponding _notebooks folder in docs_template.
    • Update notebooks to point to the corresponding path.
    • Colab notebook refs are of the form:
 [![Open In Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/github/RelevanceAI/RelevanceAI-readme-docs/blob/v0.33.2/docs/getting-started/_notebooks/Intro_to_Relevance_AI.ipynb)
  • Please add this badge in top cell of notebook as well so it can be accessed from Github.

Optional: Adding new snippets

In order to keep consistency of the code snippets throughout the repo, you can use the snippet format below to update the snippets in all places.

  1. To add new snippet
    • Add new snippets in the corresponding _snippets folder.
    • Snippets are loaded in a nested fashion. Inner most _snippets with the same name will override general snippets in docs_template/_snippets/.
    • All snippets in *.md and *.ipynb files are prefaced with @@@.
    @@@ relevanceai_installation , RELEVANCEAI_SDK_VERSION=RELEVANCEAI_SDK_VERSION @@@
    @@@ <SNIPPET_NAME>, <SNIPPET_PARAM_KEY_1>=<SNIPPET_PARAM_VALUE_1>, <SNIPPET_PARAM_KEY_2>=<SNIPPET_PARAM_VALUE_2>, ...  @@@
    • If you want to concatenate snippets, please concatenate using the following format.
    @@@ quickstart_docs; dataset_basics, DATASET_ID=QUICKSTART_DATASET_ID @@@
    @@@ <SNIPPET_1_NAME>; <SNIPPET_2_NAME>, <SNIPPET_2_PARAMS>; <SNIPPET_3_NAME>, <SNIPPET_3_PARAMS>; @@@

πŸ‘©πŸ»β€πŸ’» Building and previewing docs locally

  1. Feel free to build the docs locally in order to preview your Markdown in Vscode.

    ❯ python src/rdme_sync/build/build_docs.py -d
    

Converting notebooks to Markdown

  1. You can now convert notebooks to ReadMe Markdown either in rdmd format or block format (which allows for interactive editing in ReadMe).

        ❯ sudo apt-get install pandoc ## or brew install pandoc
        ❯ python src/rdme_sync/readme/nbconvert_rdmd.py -d -f "block"

πŸ‘©πŸ»β€πŸ’» Syncing your Changes

  1. Go the ReadMe Dash config and export the ReadMe API key $RELEVANCEAI_README_API_KEY variable from ReadMe Project Configuration
    ❯ export RELEVANCEAI_README_API_KEY='xxx'
  2. To run notebook tests, make sure to export your TEST_ACTIVATION_TOKEN from https://cloud.relevance.ai/sdk/api/. zsh ❯ export TEST_ACTIVATION_TOKEN="$TEST_PROJECT:$TEST_API_KEY:$TEST_REGION:$TEST_FIREBASEUID"
  3. Apply the changes and update the ReadMe documentations. By default, this script will sync all files in docs.
    ❯ ./src/build_sync_readme.sh
    ## Run in debug mode
    ❯ ./src/build_sync_readme.sh true
    ## Sync only a specific section, by default will sync everything in the generated `docs` folder.
    ❯ ./src/build_sync_readme.sh false docs/clustering-features
    ## Override the version, by default will create a new version from your current Git branch name
    ❯ ./src/build_sync_readme.sh false docs/clustering-features v1.0.0-my-new-version
    View your synced changes in ReadMe eg. https://docs.relevance.ai/v0.31.0/docs/quick-tour

πŸ‘©πŸ»β€πŸ’» Testing notebooks

  1. Test the notebooks for changes. By default, the script will process all notebooks in the docs folder if no --notebooks specified. This script will output error logs to the file readme_notebook_error_log.txt
    ❯ python src/tests/test_notebooks.py
    ## Run in debug mode
    ❯ python src/tests/test_notebooks.py -d
    ## Test on a selection of notebooks
    ❯ python src/tests/test_notebooks.py -d --notebooks examples/Intro_to_Relevance_AI.ipynb examples/RelevanceAI-ReadMe-Quick-Feature-Tour.ipynb
    If you have a notebook you'd like to ignore in tests, add to the notebook_ignore.txt file.

πŸ‘©πŸ»β€πŸ’» Committing your changes

  1. Install pre-commit! This helps with things like merge conflicts, linting and checking API keys to help with cleaner commits. 😊
    pre-commit install
  2. Commit your changes if what you see in the ReadMe documentation is correct! πŸŽ‰πŸ’ͺ🏻

See ./src/README.md for more details about the build and sync scripts.

πŸ‘©πŸ»β€πŸ’» Updating the ReadMe config

  1. To rebuild the config, if want to sync changes made in ReadMe
    ❯ python src/rdme_sync/config/sync.py --method 'build' --version 'v2.0.0'

For further reference

πŸ‘©πŸ»β€πŸ’» Getting Started with rdme Client

See official docs here for more details, else see rdme cheatsheet here.

πŸ“˜ Getting Started with ReadMe Markdown

See official docs here for more details, else see rdmd cheatsheet here.

Helpful Tools

  • jqplay - For crafting jq queries
  • Regexr - For validating Regex