Shared utility scripts - ISISComputingGroup/ibex_developers_manual GitHub Wiki

A place to share resources for speeding up our workflow - most of these live in https://github.com/ISISComputingGroup/ibex_utils

make_ioc batch script

Run in an EPICS terminal. Makes an IOCs support module and IOC module or an IOCs ISIS module.

Usages: For an IOC with a support and IOC module:

  • make_ioc support_folder_name ioc_folder_name
  • make_ioc mk3chopper MK3CHOPR For an IOC in the EPICS directory (will give a warning):
  • make_ioc isis_folder_name no_ioc
  • make_ioc Chopper_sim no_ioc For an IOC with only an IOC module:
  • make_ioc no_support ioc_folder_name
  • make_ioc no_support mk3chopper

Found in ibex_utils/workflow_support_scripts. To make it easy to use add the ibex_utils/workflow_support_scripts folder to your PATH.

make_ioc_test batch script

Run in an EPICS terminal. Relies on the make_ioc script above. Makes an IOC and then ask the user if they want to run tests.

Usage:

  • The same as make_ioc script but with a third parameter pointing towards the test
  • make_test_ioc oercone OERCONE oercone
  • make_test_ioc oercone OERCONE oercone.OerconeTests.test_WHEN_device_is_started_THEN_it_is_not_disabled

Found in ibex_utils/workflow_support_scripts. To make it easy to use add the ibex_utils/workflow_support_scripts folder to your PATH.

IOC Copier

Run in an Epics terminal. This should be run from within the IOC's base folder, ie. \instrument\apps\epics\ioc\master\TEKDMM40X0 if trying to duplicate the TEKDMM40X0 IOC.

Makes duplicates of an IOC correctly numbered for use when large numbers of an IOC are needed. This should only be used on IOC 2 or greater, as these IOCs link to some files in the first rather than duplicating them. Usage:

  • Copy to IOC folder.
  • Takes 4 parameters, the name of the ioc, the number ioc to copy, the first copy to create, and the last copy to make.
  • e.g. %python3% ioc_copier.py DFKPS 11 12 35
  • This would copy the danfysik using ioc-11 as the base, and create copies 12 through 35 Found in ibex_utils/ioc_copier.

GitHub Workflows

Useful GitHub Workflows and Git Hooks which can be added to project repositories

Update Submodules Automatically

A template repository which can be used when creating a submodule where you would like the parent repository to be updated automatically on push to the main / master branch of the child repository.

The repository was created in response to a discussion held in the retrospective Retrospective notes 2022.09.07 to remove the need for a check to scan repositories to ensure submodules have correctly been updated.

The repository can be used as a starting point for integration into Jenkins CI/CD.

Workflow

name: Send submodule updates to parent repo
on:
  push:
    branches:
      - main #NOTE: If adding this action to a new repo you may need to change the child repo branch name
env:
  PARENT_REPO_NAME: <GITHUB_ORGANISATION_ACCOUNT>/<PARENT_REPOSITORY> #NOTE: You may need to change the parent repo
  PARENT_REPO_BRANCH: main #NOTE: You may need to change the parent repo branch name
jobs:
  update:
    runs-on: ubuntu-latest
    steps:
      - name: Checkout ${{ github.event.repository.name }}
        uses: actions/checkout@v2
        with:
          token: ${{ secrets.PRIVATE_TOKEN_GITHUB }}
      - name: Checkout ${{ env.PARENT_REPO_NAME }}
        uses: actions/checkout@v2
        with:
          repository: ${{ env.PARENT_REPO_NAME }}
          submodules: 'true'
          ref: ${{ env.PARENT_REPO_BRANCH }}
          token: ${{ secrets.PRIVATE_TOKEN_GITHUB }}
          fetch-depth: 0
      - name: Get submodule updates
        run: |
          cd ${{ github.event.repository.name }}
          git fetch --all
          git switch ${{ github.ref_name }}
      - name: Commit and push the changes to ${{ env.PARENT_REPO_NAME }}
        run: |
          git config user.email "[email protected]"
          git config user.name "GitHub Actions - update submodules"
          git add --all
          git commit -m "Auto-update: ${{ github.event.repository.name }}" -m "This is an automatic update completed by GitHub Actions, using submodule_update.yml. It was triggered by a push to the ${{ github.ref_name }} branch of the ${{ github.event.repository.name }} submodule repo." || echo "No changes to commit"
          git push

Pylint

Place the below example in .github\workflows\ in a file called pylint.yml to add a GitHub workflow on push to a repository. The workflow will execute pylint on all .py files within the repository.

The idea behind adding this workflow to a repository is to make developers want to work towards improving the quality of python used in a repository. In doing so the repository will move towards meeting PEP8 standards.

When implementing this workflow, I recommend adding or altering the PR template for the repository to include a requirement that pylint checks must either stay the same or increase in quality. This should help prevent the codebase moving further away from PEP8 standards.

Please Note that you should modify the python version in the YAML file to reflect the version of python used in the repository.

View Suppressed Messages

To view suppressed messages when running Pylint on a given file which has pylint: disable= statements, add the flag --enable=suppressed-message to the Pylint command. Alternatively, you can run locally using: pylint --enable=suppressed-message.

Workflow

name: Pylint

on: [push]

jobs:
  build:

    runs-on: ubuntu-latest

    steps:
    - uses: actions/checkout@v2
    - name: Set up Python 3.8
      uses: actions/setup-python@v1
      with:
        python-version: 3.8
    - name: Install dependencies
      run: |
        python -m pip install --upgrade pip
        pip install pylint
    - name: Analysing the code with pylint
      run: pylint --rcfile=.pylintrc $(find . -name "*.py" | xargs)