Skip to content

Template for crafting beautiful trainings with dynamic lab environments in an automated manner

License

Notifications You must be signed in to change notification settings

abrahimi93/training-as-code

 
 

Repository files navigation

training-as-code

This is a training template based on remark.js (v.0.15.0). It is based on Markdown/JavaScript/HTML and offers the following advantages over conventional presentation software such as LibreOffice Impress and Microsoft PowerPoint:

  • It only requires a web browser
  • It also works on smartphones, tablets and other touch-optimized devices
  • It can be used with version control systems such as Git as content is text/plain
  • You can use any text editor and operating system you like to create and display presentations
  • It's free (and hip!)

Automatic builds

When used in GitLab all Markdown documents (*.md) will be automatically build into a HTML presentation and PDF document which can then be downloaded as job artifact. This allows distributing your slides easily.

To manually create/update the HTML presentation, run the build.py utility. It requires Python 3.

Handout

A handout will be created from the file handout.md. It has only basic styling applied to it.

Usage

Clone this repository and have a look at the example training (01-content.md). The format is markdown, you can leverage an editor such as VSCodium and to edit the file and preview changes:

vscodium browser

Check out the following websites for more information about Markdown:

You can also check-out the official remark.js website for further examples.

Presenter View

The presenter should download the artifact from the collect files pipeline job and extract these to wherever (s)he pleases. Then open presentation.html with your browser.

Press ? to see a list of all available commands.

Pressing p will open a presenter view that shows the current slide, the next slide and speaker notes.

Multi-Screen Setup

A common setup has one screen that presents to the audience and another that shows the information for the speaker.

To achieve this press c in the presentation in order to clone it. The screens are linked and moving forward on the clone will move the other forward aswell.

You can move the window to another screen and sent it into fullscreen in most browsers by F11?

By then pressing p on the cloned presentation you will have your presenter view there.

Markdown macros

remark.js uses some Markdown, macros - e.g. for resizing images:

![:img Paula Pinkepank, 25%](assets/imgs/ridley.jpg)

The value before the colon represents an alternative text in case the image cannot be loaded. The value describes the image width in percentage.

New slides are defined by the following line:

---

In order to add presentation notes, use the following code before the next slide:

???

Notes

Incremental slides (slides that add more information after a button press) can be added with the following:

This is already visible

--

This text will only be visible when going to the next element.

Tweaks

Set title

You can simply change the title by altering the settings.ini file:

[meta]
title=Zeit unproduktiv vergeuden leicht gemacht

Change screen ratio

By default, the ratio 16:9 is selected, but you can also override this in settings.ini by changing the ratio line:

[layout]
ratio=4:3

Set customer name as watermark

Before sending presentations to customers you can set their company name as watermark. To do so, edit settings.ini:

[meta]
title=Zielgruppenorientierte Memes in Präsentationen
customer=Simone Giertz Ltd.

While the customer name could be removed from presentation.html, it can't be changed in the PDF version.

Deploying lab environment

Local

Ensure meeting the following requirements:

For deploying the lab on a local machine, simply clone this repository to a host and switch to the Vagrant folder. Run the following command to create and configure the VM:

$ vagrant up
Bringing machine 'default' up with 'virtualbox' provider...
==> default: Importing base box 'centos/8'...
==> default: Matching MAC address for NAT networking...
==> default: Checking if box 'centos/8' version '1905.1' is up to date...
...
PLAY RECAP *********************************************************************
default                    : ok=5    changed=3    unreachable=0    failed=0    skipped=0    rescued=0    ignored=0

Cloud

For deploying the lab in the cloud, a provider-specific configuration needs to be created within the Terraform folder.

Creating the environment differs per provider, but mostly the following commands are necessary:

$ terraform init
$ ssh-keygen -f clouduser
$ cp azureuser ../../Ansible/files
$ terraform plan -var-file=credentials-<name>.tfvars
$ terraform apply -var-file=credentials-<name>.tfvars

To configure the VMs using Ansible after creating the VMs, run the following commands:

$ ansible-playbook -i inventory.py ../../ansible/node.yml --flush-cache

Testing

VM customization

For the VM customization, unit tests can be found in the Ansible folder. To run them, execute the following command within the VM:

$ pytest-3 /vagrant/ansible/test_generic.py
=== test session starts ===
platform linux -- Python 3.6.8, pytest-3.4.2, py-1.5.3, pluggy-0.6.0
rootdir: /vagrant/ansible, inifile:
plugins: testinfra-5.2.2
collected 3 items
test_generic.py ... [100%]

=== 3 passed in 0.09 seconds ===

When using a cloud environment, you can also leverage Ansible from your Terraform configuration to run the tests:

$ py.test --connection=ansible --ansible-inventory=inventory.py ../../Ansible/test_generic.py --sudo

Note that this will require dynamic inventory.

Participant lab solution

Participants can easily check whether they succeeded a lab by running the following command:

$ lab 1
Checking lab 1

[1/2] Checking Good Task... Success!
[2/2] Checking Bad Task... Failure!

Errors in 1 task

1 needs to be replaced with the lab number.

Automated validation of lab solutions

Automated testing of lab solutions can be performed by placing test definition, written in commander syntax, in the labs/test directory.

When working with the example Vagrantfile in vagrant, the command lab becomes available inside the VM. Using it inside of the labs folder, which is placed inside the users home directory checks for either a single lab, or the whole suite can be performed. See lab -h for more information.

Pipeline configuration

A GitLab CI/CD configuration is part of this repository. It executes the following tasks:

  1. Render HTML from Markdown files
  2. Build PDF presentation for sharing with participants
  3. Create handout PDF from handout.md
  4. Collect all the files necessary for a training (presentations, additional content and handout)

It should be easy to migrate this logic to other pipelines such as GitHub Actions.

Further notes

See also the official remark.js README for more details.

About

Template for crafting beautiful trainings with dynamic lab environments in an automated manner

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 72.7%
  • CSS 17.6%
  • HTML 9.7%