Open Source Your Knowledge, Become a Contributor

Technology knowledge has to be shared and made accessible for free. Join the movement.

Create Content

Concept of Viewer

A viewer is an HTTP service that renders content from the runner to an <iframe> inside the playground page. You can create your own HTTP server from your code or use a simplified server given by Tech.io.

It is possible to launch a viewer at anytime during the execution of a test by using the Open command.

Use a Viewer

First, create a playground using a template of your choice. In this example, we are using the NodeJS template. Then, create a www folder at the root of your project (/nodejs-project/www). Add a simple HTML file named HelloWorld.html with the following code:

<html>
    <head>
        <title>Hello World!</title>
    </head>
    <body>
        <h1>Hello World!</h1>
        <p>This page is served by the static viewer</p>
    </body>
</html>

Open the server from a command

Open the nodejs-project/universe.spec.js file and add a command after the line it('should sum stars', function () {:

it('should sum stars', function () {
  console.log('TECHIO> open -s /project/target/www HelloWorld.html');

Here we use some new syntax... the TECHIO> prompt. Each time there is a TECHIO> prompt on the standard output, the platform will consider it as a command.

Let's analyze the command:

TECHIO> open -s /project/target/www HelloWorld.html
  • TECHIO>: Execute a Tech.io command
  • open: Open a viewer on a HTTP flux
  • -s: Specify to use a simple server by defining a folder
  • /project/target/www: The folder you want to use as a root folder for the server. More details below.
  • HelloWorld.html: The file you want to load in the <iframe> of the viewer

Why /project/target/www?

As discussed in the adding a coding exercise section, when your project is built a Docker image is created and your project is copied into this image in the /project/target directory. So if you want to expose a folder inside this project (like the www folder), you need to prefix the path with /project/target. This means that you can also reference any folder in your Docker image. For example, if a coding exercise generates some HTML files based on the code of the user and are stored in the filesystem in /var/www/html, you can use this folder.

Test your playground

Commit your changes and push your code. Then, run the coding exercise. You should see a viewer displaying your html file.

Furthermore

If you want to create a more complex server and not serve only a folder of static files, do not use the -s option. Check the full documentation of the open command.

Here is a dedicated playground to show how to use server and viewer: Dynamic viewer with server.

Here are some classical use cases for the use of a viewer:

  • Playgrounds around a HTTP stack (NodeJS, Play!Framework, Spring Boot, etc.)
  • Playgrounds around Front-End technologies (AngularJS, React, etc.)
  • Playgrounds with Plots (such as Data Science courses, R plotting, etc.)
  • Playgrounds with Interactive Contents (Games, Web application development, etc.)
  • Playgrounds with Visual Interface over Databases (Neo4j Browser, etc.)
Open Source Your Knowledge: become a Contributor and help others learn. Create New Content