Educator Start Guide
With Educational Products, you can learn programming languages in the form of coding tasks and get instant feedback right inside of IDEs based on JetBrains IntelliJ Platform.
Educational Products support Java, Kotlin, Python, Scala, JavaScript, Rust, C++ and Go with more to come.
Choose your programming language
This tutorial will walk you through creating a simple JavaKotlin PythonScalaJavaScript RustC++Go course with a set of programming tasks and integrated tests. You can switch to a different programming language using the Section drop-down menu at the top of the page:
Prerequisites
You can create a Java course in IntelliJ IDEA with EduTools plugin installed.
Download IntelliJ IDEA Edu , or Install EduTools Plugin if you have already installed IntelliJ IDEA Community or Ultimate.Prerequisites
You can create a Kotlin course in IntelliJ IDEA or Android Studio with EduTools plugin installed.
Prerequisites
You can create a Python course in PyCharm.
Download PyCharm Edu , or Install EduTools Plugin if you have already installed PyCharm Community or Professional.Prerequisites
You can create a Scala course in IntelliJ IDEA with EduTools plugin installed.
Download IntelliJ IDEA Edu , or Install EduTools Plugin if you have already installed IntelliJ IDEA Community or Ultimate.Prerequisites
You can create a JavaScript course in WebStorm, IntelliJ IDEA Ultimate and PyCharm Professional with EduTools plugin installed.
Download WebStorm, IntelliJ IDEA Ultimate or PyCharm Professional bundled with evaluation license key for a free 30-day trial, and Install EduTools plugin.If you are a student or academic staff member, apply to our Educational Licenses Program to get access to all JetBrains desktop products, including WebStorm.
Prerequisites
You can create a Rust course in CLion with EduTools and Rust plugins installed.
Download CLion bundled with evaluation license key for a free 30-day trial, and Install EduTools Plugin. Alternatively, you can download IntelliJ IDEA Edu.To learn how to install the Rust plugin, see this guide.
Prerequisites
You can create a C++ course in CLion with EduTools plugin installed.
Download CLion bundled with evaluation license key for a free 30-day trial, and Install EduTools Plugin.If you are a student or academic staff member, apply to our Educational Licenses Program to get access to all JetBrains desktop products, including CLion.
Prerequisites
You can create a Go course in GoLand and IntelliJ IDEA Ultimate with EduTools plugin installed.
Download GoLand or IntelliJ IDEA Ultimate bundled with evaluation license key for a free 30-day trial, and Install EduTools Plugin.If you are a student or academic staff member, apply to our Educational Licenses Program to get access to all JetBrains desktop products, including GoLand.
Start teaching
Creating a course
-
When installed for the first time, the IDE asks if you're a Learner or an Educator. Choose Educator to enable course creation functionality:
-
When installed for the first time, the IDE asks if you're a Learner or an Educator. Choose Educator to enable course creation functionality:
-
When installed for the first time, the IDE asks if you're a Learner or an Educator. Choose Educator to enable course creation functionality:
-
When installed for the first time, the IDE asks if you're a Learner or an Educator. Choose Educator to enable course creation functionality:
-
When installed for the first time, the IDE asks if you're a Learner or an Educator. Choose Educator to enable course creation functionality:
-
To create a new course, go to
from the or in the , fill in the title, author and description: -
Every course created with your IDE is structured as a list of lessons. Each lesson contains tasks.
A task has the following components:
a task.html description file,
a main.go file with main function declaration,
a Task.java Task.kt task.py Task.scala lib.rs task.js task.cpp task.go file with exercise code,
Test.java Tests.kt test_task.py Test.scala tests.rs test.js test.cpp task_test.go file with the task check,
CMakeLists.txt file that contains a set of directives and instructions describing the project's source files and targets,
any other files needed for the learner to complete the task.
Go to
or invoke Alt+1 to look at the course structure: -
Add more lessons, tasks, or group lessons into sections via the
, drag-n-drop items to reorder them.To rename items right-click them in the menu use
or invoke Shift+F6:
Working with tasks
Open the main.go file to declare the main function, for example:
package main import ( "fmt" task "task1" ) func main() { fmt.Println("The result of sum is:", task.Sum(2, 3)) }-
Open the Task.java Task.kt task.py Task.scala task.js lib.rs task.cpp task.go file to write the code you want for the exercise, for example:
class HelloJava { public static void main(String[] args) { System.out.println(sayHello()); } private static String sayHello(){ return "Hello, Java!"; } }fun hello(): String = "Hello, Kotlin!" fun main(args: Array<String>) { println(hello()) }def test_sum(a, b): return a + b print("Sum is", test_sum(1, 2))object Task extends App { def hello() = { "Hello, Scala!" } println(hello()) }pub fn hello_world() -> String { String::from("Hello, World!") }function sum(a, b) { return a + b; }#include <iostream> int sum(int a, int b) { return a + b; } int main() { std::cout << sum(1, 2) << std::endl; }package task func Sum(a, b int) int { return a + b } -
Choose the Run option from the context menu or press Shift+F10 to run your code and check if it works as expected:
Choose the Run option from the context menu or press Shift+F10 to run your code and check if it works as expected:
Choose the Run option from the context menu or press Shift+F10 to run your code and check if it works as expected:
Choose the Run option from the context menu or press Shift+F10 to run your code and check if it works as expected:
Choose the Run option from the context menu or press Shift+F10 to run your code and check if it works as expected:
Choose the Run option from the context menu or press Shift+F10 to run your code and check if it works as expected:
Go to
or press Shift+F10 to run your code and check if it works as expected:Go to
option from the context menu or press Shift+F10 to run your code and check if it works as expected: -
Once the code is ready, select a fragment you want a learner to fill in, invoke
command from the context menu and add the placeholder text and some hints to help the learner find the right solution: -
If you want to see how your task will look to the learner, right-click the Task.java Task.kt task.py Task.scala task.js lib.rs task.cpp task.go file in the Project tool window, and choose :
-
Now it's time to add the task description. Click the Edit icon at the top of the panel, or just open task.html file. Preview all the changes on the panel while editing.
Writing tests
-
You can write your custom tests to automatically verify the learner's solution. Every task has a Test.java Tests.kt test_task.py Test.scala tests.rs test.js test.cpp file that you will need to modify:
-
Let's replace the test file content with the following:
import org.junit.Test; import static org.junit.Assert.*; public class HelloJavaTest { @Test public void testSolution() { assertEquals("You should say hello to Java", "Hello, Java!", HelloJava.sayHello()); } }import org.junit.Assert import org.junit.Test class Test { @Test fun testSolution() { Assert.assertEquals( "You should say hello to Kotlin", "Hello, Kotlin!", hello()) } }import unittest from ..task import test_sum class TestCase(unittest.TestCase): def test(self): self.assertEqual(3, test_sum(1, 2), msg="1 + 2 = 3")import org.junit.runner.RunWith import org.scalatest.junit.JUnitRunner import org.scalatest.FunSuite @RunWith(classOf[JUnitRunner]) class TaskTest extends FunSuite { test("Task.hello") { assert(Task.hello === "Hello, Scala!") } }use task1::hello_world; #[test] fn test() { assert_eq!("Hello, World!", hello_world()); }test('adds 1 + 2 to equal 3', () => { import_task_file("task.js"); expect(sum(1, 2)).toBe(3); }); }#include <gtest/gtest.h> int sum(int a, int b); TEST(SumTest, Simple) { ASSERT_EQ(sum(1, 2), 3); }package test import ( task "task1" "testing" ) func TestSum(t *testing.T) { type args struct { a int b int } tests := []struct { name string args args want int }{ {"1", args{1, 1}, 2}, {"2", args{1, 2}, 3}, } for _, tt := range tests { t.Run(tt.name, func(t *testing.T) { if got := task.Sum(tt.args.a, tt.args.b); got != tt.want { t.Errorf("Sum() = %v, want %v", got, tt.want) } }) } } -
To check that your code passes your own tests,click the Check button at the bottom of the Task Description panel. If your code and test are correct, you will see the Correct message:
Course preview
-
When you have finished creating your course, it's a good idea to view your course from a learner's perspective and test it. Right-click the course view and go to
to open your course in learner mode: -
So you can verify the course structure:
-
Solve tasks with the
button and verify the wrong answer feedback: -
Check your hints and links available in the task description:
-
Check your hints and links available in the task description:
-
Check your hints and links available in the task description:
-
Check your hints and links available in the task description:
-
Compare the solution with the suggestions and verify the suggested solution
-
Compare the solution with the suggestions and verify the suggested solution
-
Check your hints and links available in the task description:
-
Check your hints and links available in the task description:
-
Check the right answer feedback:
Course sharing
-
You can share your learning materials publicly or privately with your students or co-workers on Stepik, a learning management and MOOC platform. Or you can save your course as an archive file.
-
To save your course as a zip file, go to
action.The generated archive can be opened via the Browse Courses available from the
and in the with the icon: -
If you have an account on Stepik, you can easily upload your course there, update it anytime you need, and share publicly or privately.