Skip to content

psk907/iat-ci-workshop

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

14 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

GitHub® Actions
MATLAB

Continuous Integration (CI) configuration examples for MATLAB®

Are you interested in automating your testing with CI?

Not sure how to connect MATLAB with CI systems?

We've got you covered!

This repository makes it easy to run your MATLAB tests on some of the most common CI platforms. The configuration files take care of setting up MATLAB to work with the CI system and automatically executing your MATLAB tests.


Getting started

Quick start guide

Here's how to quickly get this repository running on a CI system:

  1. Fork the repository to your own GitHub account
  2. Go to one of the supported CI platforms and install the available MATLAB CI plugin Note: GitHub Actions does not require this step
  3. Create a new CI job using your forked repository
  4. Enjoy using CI with MATLAB!

That's really it!

To use your MATLAB code or Simulink® models with this repository, simply replace the existing code and tests in "source" and "tests" with your own code and tests. There's no need to modify any of the CI configuration files because they are all completely agnostic of the MATLAB code being used.

Notes:

  • In most cases, the configuration files will automatically get picked up by the CI platform during step 3, but some platforms may require you to specify which file to use
  • The default branch for this repository is "main"

Step-by-step getting started guide for GitHub Actions

Our Continuous Integration with MATLAB and GitHub Actions Workshop provides a step-by-step guide for getting started with GitHub Actions.


Badges

Badges look really great, but they're not always easy to set up. Take a look at the badges, badge code, and reference links below to get started with badges for your repository.


GitHub Actions
Badge MATLAB
Badge Code [![MATLAB](https://github.com/GITHUB_USERNAME/GITHUB_REPO_NAME/actions/workflows/ci.yml/badge.svg)](https://github.com/GITHUB_USERNAME/GITHUB_REPO_NAME/actions/workflows/ci.yml)
Badge Help GitHub Actions documentation for setting up badges

How to use the Badge Code:

  1. Copy-paste the badge code into your README.md file
    • The badge code you copy should start with "[!" and not "\[\!"
  2. Replace all BOLD+ITALIC names with your specific credentials/names
    • Replace GITHUB_ORG with your GitHub organization name (usually your GitHub username)
    • Replace GITHUB_REPO_NAME with the name of your GitHub repository
    • Replace SOURCE_CONTROL_SYSTEM with the name of the source control system you are pointing to (gh = GitHub, bb = BitBucket)
    • Replace DEFAULT_BRANCH_NAME with the repository branch name you want to get the pipeline status from

About the code

The primary goal of this repository is to provide a set of configuration files as templates that illustrate how to run MATLAB on various CI platforms (e.g., Azure DevOps, CircleCI, GitHub Actions, Jenkins).

Each of these pipeline definitions does four things:

  1. Install the latest MATLAB release on a Linux®-based build agent
  2. Run all MATLAB tests in the root of your repository, including its subfolders
  3. Produce a test results report (if necessary)
  4. Produce a code coverage report in Cobertura XML format for the source folder

The example MATLAB code example dayofyear.m is a simple function takes a date string "mm/dd/yyyy" and returns the day-of-year number.

Notes:

  • MATLAB already includes a day-of-year calculation using day(d,"dayofyear"), where d is a datetime object. This code is only used as an example since it is a concept that is familiar to most people.
  • The code coverage is intentionally set below 100% to show how missing coverage looks with badges. Uncomment the last test in TestExamples.m to increase the coverage to 100%.

There are 2 test classes provided:

  1. TestExamples.m - A simple set of equality and negative tests
  2. ParameterizedTestExamples.m - A set of 12 equality tests set up using the parameterized test format

The repository includes these files:

File Path Description
source/dayofyear.m The dayofyear function returns the day-of-year number for a given date string "mm/dd/yyyy"
tests/TestExamples.m The TestExamples class provides a few equality and negative tests for the dayofyear function
tests/ParameterizedTestExample.m The ParameterizedTestExample class provides 12 tests for the dayofyear function using the parameterized test format
.github/workflows/ci.yml The ci.yml file defines the pipeline that runs on GitHub Actions

Caveats

  • On cloud-hosted agents provided by Azure DevOps, CircleCI, and GitHub Actions, you need a MATLAB batch licensing token if your project is private or if your pipeline includes transformation products, such as MATLAB Coder™ and MATLAB Compiler™. You can request a token by contacting MathWorks® at batch-tokens@mathworks.com.

Links


Contact Us

If you have any questions or suggestions, please contact MathWorks at continuous-integration@mathworks.com.

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • MATLAB 100.0%