=Paper= {{Paper |id=Vol-2531/paper05 |storemode=property |title=Towards an Online Programming Platform Complementing Software Engineering Education |pdfUrl=https://ceur-ws.org/Vol-2531/paper05.pdf |volume=Vol-2531 |authors=Niels Gandraß,Torge Hinrichs,Axel Schmolitzky |dblpUrl=https://dblp.org/rec/conf/seuh/GandrassHS20 }} ==Towards an Online Programming Platform Complementing Software Engineering Education== https://ceur-ws.org/Vol-2531/paper05.pdf
       Towards an Online Programming Platform
     Complementing Software Engineering Education
                                               Niels Gandraß, Torge Hinrichs, Axel Schmolitzky
                                                  Hamburg University of Applied Sciences
                                                             Hamburg, Germany
                                    {niels.gandrass, torge.hinrichs, axel.schmolitzky}@haw-hamburg.de


   Abstract—Existing online programming platforms provide                                     an assignment, and an automatic feedback mechanism for the
many opportunities for individuals to develop and improve their                               proposed solutions. Such platforms can be used by students
programming skills. Using descriptive assignments that address                                who want to gain more experience in programming.
different skill levels these platforms target both beginners and
experienced programmers. We used one such platform featuring                                     Currently, a growing number of OPPs can be observed.
advanced exercises in a project course during the fifth semester                              Some of these aim primarily at programming beginners who
of our bachelor degrees in computer science and were surprised                                are just starting to learn the very basics of coding; in the
by its success and the high motivation of the participants.                                   following we refer to such platforms as Introductory OPPs.
Nonetheless, we also observed deficits of the platform with regard
                                                                                              Others (we call them Professional OPPs) aim at recruit-
to software engineering aspects. In this paper we identify require-
ments for an online programming platform that complements                                     ing experienced programmers who program professionally,
software engineering education and match existing platforms                                   have substantial experience in more than one programming
against these proposed requirements.                                                          language and who still like to solve complex problems in
   Index Terms—education, online assessment, online program-                                  their spare time. Such professional programmers typically
ming platform, programming, software engineering education,
                                                                                              know how important maintainable code and a solid soft-
team programming
                                                                                              ware architecture is. We miss something in between (an
                         I. I NTRODUCTION                                                     intermediate OPP) for what we call advanced programmers,
     “It was observed that game based learning act as                                         loosely classified as having at least one year of programming
     a good alternative over regular lab assignments                                          experience in one language, in the middle of a computer
     and rote learning. Through competitions and coding                                       science curriculum. Students at this stage are just starting
     challenges, students tend to develop interest and                                        to abstract from concrete mechanisms of one programming
     therefore are expected to learn more quickly and                                         language, ideally through comparison with another language.
     think more creatively. Hence, digital game based                                         They get in contact with design patterns, they learn that an
     learning should be incorporated in our education                                         algorithm can be implemented in different ways (some of them
     system as it offers unique structure to compliment                                       even unnoticed wrong), struggle to write readable code, start
     traditional strategies, infusing teaching with energy,                                   breaking down larger programs into modules, and designing
     spark innovative thinking and provide diversity in                                       their interfaces. An intermediate OPP should support all of
     teaching methods.” — Papastergiou, 2009 [1]                                              this with appropriate assignments. Such a platform should
                                                                                              explicitly address the code quality of the submitted solutions
   A key aspect of software engineering is programming [2].                                   and it also should support programming in teams.
In any software development team at least one person actively                                    In this paper we start by describing the benefits and short-
has to produce source code and all team members are required                                  comings we observed while using an OPP within a bachelor
to have an understanding of its complexity. The ability to                                    project at the Hamburg University of Applied Sciences (HAW
program is necessary to follow technical details as well as                                   Hamburg). Taking these findings as a baseline, we then derive
to judge the feasibility of complex systems. Developers who                                   requirements for an OPP that incorporates software engineer-
are strong in both understanding and producing source code                                    ing aspects and offers support for collaborative team work
will get productive faster in new projects or while analysing                                 to be used in the computer science education at universities.
complex scenarios [3]. Therefore, the ability to program is                                   Lastly, already available platforms are analysed and compared
the most important skill that software engineering students                                   against our derived requirements.
need to acquire. The better the programming education in
a curriculum, the more promising the software engineering                                                    II. BACKGROUND : T HE PHATAI P ROJECT
education, which later builds upon it, will be.
   The individual ability to program can be trained with the                                    The Bachelor in Computer Science (BCS) degrees at the
help of an Online Programming Platform (OPP). We define an                                    HAW Hamburg traditionally have a strong emphasis on pro-
OPP as a web-based platform that offers several assignments                                   gramming, most modules in the curricula rely on the program-
of varying complexity, a possibility to enter code that solves                                ming abilities of their participants. But still students in higher




S. Krusche, S. Wagner (Hrsg.): SEUH 2020                                                                                                                           27


                         Copyright © 2020 for this paper by its authors. Use permitted under Creative Commons License Attribution 4.0 International (CC BY 4.0).
semesters experience difficulties to model abstract or complex
problems in source code.
   In the fifth semester of all HAW Hamburg BCS curricula,
students have to attend a project module (we call the formal
module BCS Project or just Project in the following), in
which they are supposed to work independently in a team and
solve a larger problem, using software engineering techniques
imparted during the third and fourth semester. The subjects
of the projects depend on individual offers by staff members
of the department and vary every semester. Students may
choose from this range of offers and only a short list of the
initially offered projects (typically the most voted ones) can
take place. The Project awards 9 ECTS Credit Points (CPs)
that are typically translated to a weekly workload of 12 hours
for the participants; only three of these hours are contact time
with the lecturers.
   In one of these projects, during the summer term of
2019, we conducted an experiment [4]: the participants had                    Figure 1. CodinGame’s web-based user interface
to solve problems of increasing complexity on the OPP
CodinGame [5], first simple quizzes as individuals to become       entities, as shown in figure 1. Programmers can see how their
acquainted with the platform, later, in teams of four, three of    solutions perform; such a visualization of object interaction
the much more complex arena games. Before we can describe          is also a well-received key concept of the programming
our project concept in detail, we have to describe some core       environment Greenfoot [6]. Additionally, interactive controls
concepts of CodinGame.                                             allow pausing and continuing the execution, stepping forward
A. CodinGame: An Online Programming Platform                       or backward, rewinding to the beginning or fast-forwarding to
                                                                   the end of a battle. This gives the programmer fine-grained
   CodinGame is an OPP with a focus on recruiting program-         control over the execution and allows to analyse the effects of
mers, thus aiming primarily but not exclusively at experienced     an improvement or the tactics of the opponent.
coders. It offers a large variety of programming assignments,         A user of the platform can run a proposed solution against
ranging from simple ones with just conditions and loops,           a subset of the test cases of an assignment, which includes
up to complex scenarios that require, for example, graph           the compilation of the source code. If the code compiles and
algorithms or machine learning. It further offers a wide variety   stands these tests, the user then can submit the code and it
of assignment conduction types, from single person exercises       will be run against all test cases. In arena games, as was said
over programming battles in small groups up to arena games         before, the solution will also battle against other solutions.
where the success of an implementation can be ranked in            Thus, especially for the arena games, a programmer typically
world-wide leagues. For most assignments the success of a          goes through multiple program-submit cycles, over a longer
solution is measured with unit tests, whereas the solutions        period of time (from hours over days up to even weeks).
of the arena games battle against a large number (typically           We chose this platform for our project because one of us
around 100) of other solutions in the same league to get their     had substantial personal experience with it.
score and rank. Beginners of an arena game always start in
the Wood League and can climb up through the Bronze, Silver        B. Integration Into a Classroom Teaching Scenario
and Gold League into the League of Legends. In some arena             For our new version of a BCS Project we coined the
games, the complexity of the assignment increases in higher        acronym PHATAI, for “Program Hard And Talk About It”.
leagues through the introduction of additional rules.              The “program hard” part can easily be served simply by using
   One key feature of CodinGame is its use of standard-IO          any OPP; but we wanted the participants to not only improve
(i.e. the console): each assignment describes the input format     their individual programming skills, but also their ability to
a proposed solution will get in textual form via standard input    talk about their design process and design decisions with the
and specifies the (syntax of the) output the solution has to       goal of giving useful information to others, i.e. their ability to
produce textually via standard output. This simple unification     act as team players and benefit from it.
concept allows the platform to support a large variety of             After a warm-up phase of two weeks with individual coding
programming languages for the same assignment; most OPPs           of CodinGame quizzes, we split the participants up into three
are based on this general principle. At CodinGame a user can       teams of four and kept these teams for the rest of the semester.
choose from up to 27 languages.                                    The teams went through three iterations, each with the same
   Another key feature of CodinGame is the visualization           basic structure - Coding, Presentation of Results, Improve
of solutions. Many assignments, especially the arena games,        Coding, Short Presentation of Improvements - as shown in
offer an animated, two-dimensional view of the programmed          figure 2.




S. Krusche, S. Wagner (Hrsg.): SEUH 2020                                                                                           28
 Sa   e   c m eii                                                              end of the third arena game iteration the students made fair
                                                                               use of the git repository, started building architectures that
                                                                               also allowed parallel work on different components and tried




                                             eam
           Initial Phase                           Improvement Phase
              (2 weeks)                                  (2 weeks)
                                                                               to comply with established coding conventions.




                                            he
          C ea e           e                        Im     e    l i
                                                                               C. Lessons Learned




                                       f m
                    S a d-                                  S a d-
                    mee i g                                 mee i g               The overall success of the project was a surprise. Pro-


                                     idea
                    (week 1)                                 (week 3)          gramming on a platform with attractive visualizations of the
                                 ae                                            solutions in combination with competitive rankings turned out
               Pe e ai                                    Pe e ai
                                                                               as highly motivating for the students. The project gave the
                               I c



                (30 minutes)                               (15 minutes)        participants the time to delve deeply into coding and problem
                                                                               solving, so that they even liked to give talks about it.
                                                               Ne    c m eii      But there were also some downsides. One of the arena
                                                                               games was taken off the platform in the middle of its iteration;
           Figure 2. A challenge iteration in the PHATAI project               the lecturers had no control over it. The platform offers no
                                                                               support for team work: neither does it support the use of a
                                                                               repository nor does it encourage to split an implementation
   The initial coding phase lasted two weeks. After the first                  into suitable modules since the editor allows just one compi-
week, the lecturers held an interim stand-up meeting with                      lation unit. The quality of the code is completely irrelevant -
each team separately to get an impression of the progress.                     the ranking depends solely upon the effective textual output
After the two weeks, in a plenary session each team had                        of a solution.
to give a 30 minutes presentation of the design and the
concepts (algorithms, data structures, . . . ) of its solution. Each                   III. I DENTIFYING P LATFORM R EQUIREMENTS
team then got another two weeks to improve its solution                           One outcome of the PHATAI project, as described in the
(again with interim stand-up meetings), ideally also based                     previous section, is that we will repeat it in a similar form in
on the information gathered during the talks. Finally, a 15                    the summer term 2020. Some aspects will be improved, but we
minutes presentation had to be given by each group on the im-                  will again stick with CodinGame for that pass. Nonetheless,
provements. Even though CodinGame offers 27 programming                        we see a clear demand for an OPP that offers improved
languages, we decided that Java had to be used exclusively in                  support for aspects relevant to software engineering education.
all coding challenges. This allowed for a better comparison of                 Therefore, we identified basic requirements for such an OPP
the developed solutions.                                                       that would better suit our needs. These requirements are based
   One highly motivating effect during such an iteration was                   on our experiences gathered from the PHATAI project as well
that each solution was automatically ranked by the platform;                   as from the usage of Moodle1 based online Java programming
a higher rank typically indicated a better solution. But if the                assignments [7] in introductory programming education (first
final rank after four weeks were the only criterion for success,               and second semester).
the project would have been all about coding only. Therefore                   A. Stakeholder Analysis
we defined success differently: After the presentations, all
                                                                                  The first step towards requirements is an analysis of the
participants had to mark the usefulness of the talks of the
                                                                               stakeholders including their individual goals and needs. Each
other groups. After three iterations of being graded by peers,
                                                                               stakeholder has a different point of view and pursues different
the team with the highest “reputation” won a small prize (a
                                                                               objectives working with the platform. While the number of
set of Rocket Books, sponsored by a friendly company located
                                                                               stakeholders is potentially larger, the following sections focus
in Hamburg).
                                                                               on the most important ones. We identified four main roles,
   Because there is no support for team programming on
                                                                               namely: Student, Lecturer, Developer, and Administrator. In
CodinGame, the teams had to organize their collaboration on
                                                                               the following we describe their primary goals as well as their
their own; the lecturers just required the use of a GitLab in-
                                                                               behaviour during usage and operation of the aspired platform.
stance where they were granted access to the code repositories.
                                                                                  1) Student: The role Student denotes users of the platform,
This allowed additional plenary sessions in which the quality
                                                                               i.e. persons spending a considerable amount of their time
of the code could be discussed.
                                                                               on solving provided assignments to improve their skills. As
   At the end of the semester, each group had given a total                    users could also be interested lecturers or other non-students
of six presentations. The quality of the presentations clearly                 having access, this role has to be distinguished from the formal
improved over the time of the project: The presented UML                       student status at universities. We still decided to name this role
diagrams and code snippets became more readable; the stu-                      Student, as students are the main target group of the platform.
dents became more confident and their talks more focused.                         Students are participants in any given course that is available
Furthermore, we observed that the quality of the team work                     via the OPP. If using the platform within a university course
improved: at the start of the first arena game we observed
mainly “lonesome hacking” and almost no team work; at the                        1 Moodle project website: https://moodle.org/ (visited on 10/18/2019)




S. Krusche, S. Wagner (Hrsg.): SEUH 2020                                                                                                                 29
is mandatory for students, they then can be further categorized      to complete exercises without the possibility to link negative
into two subsets. The first consists of students that are highly     results to their real identity (STD-04). This can be especially
motivated and that aim at learning new skills and improving          relevant for students of the second identified group, which are
their existing ones. In contrast, the second set contains students   still feeling insecure about programming.
whose primary goal is to pass the course or who lack extra              From a students perspective the platform has to be easy to
time to spend improving their skills due to the workload of          understand and use during the work on assignments. There-
other courses or for personal reasons.                               fore, no complicated setup or configuration should be required.
   2) Lecturer: A lecturer wants to utilize such a platform          In addition, the development environment shall be support-
to improve the quality of his course by giving students an           ive, through functionality such as syntax highlighting, auto-
opportunity to practice and repeat lessons, or even allowing         completion and “search and replace” as known by existing
for an optional deeper dive into a certain topic. In our context     developer tools (STD-05). This is particularly important for
every person that provides coherent sets of exercises for the        students of the first group, which already have programming
OPP falls into this category. From a software engineering            knowledge and used professional development environments
lecturers point of view it is desirable to shift the focus away      before. It shall also be possible for a student to get hints or ad-
from sole technical details towards a more abstract, method          ditional assistance, when stuck during an assignment, in order
or concept based approach incorporating software engineering         to primarily support programming beginners (i.e. the second
aspects.                                                             student group) and keep up their motivation (STD-06). The
   3) Developer: An OPP should be designed for continuous            solution progress shall also be visible at any time (STD-07).
improvement and development. Developers for an OPP can be            In case of syntax errors, the editor shall assist the student in
divided into platform developers and assignment developers.          solving the issue (STD-08). Evaluation of the current solution
The primary goal of a platform developer is to implement new         and generating feedback accordingly shall be possible at any
features and fix bugs that were found during operation of the        time and be quickly available (STD-09).
platform. A platform developer also provides the ecosystem              Another central requirement is that students should be able
for assignment developers that design and implement new              to work in teams of variable sizes (STD-10). Accordingly, it
assignments for the platform. Ideally it is (technically) less       is required that the platform can handle solutions build from
demanding to develop a new assignment than to develop the            multiple files coming from various input buffers (STD-11).
platform itself. Such a distinction has been successful for          Moreover, the integration of a version control system (e.g.
example in the Greenfoot programming environment [6].                Git), that enables features such as file revising, branching,
   4) Administrator: Administrators are responsible for the          code collaboration, and rollback, is a desired feature (STD-12).
operation and maintenance of the platform. This includes             Furthermore, it shall be possible for teams to compare their
deployment of the OPP software as well as the hardware and           solutions against each other in the form of code reviews and
other resources required to run it, e.g. servers or network          course-wide competitions (STD-13).
bandwidth. Their key objective is to provide the needed                 2) Lecturers: The platform shall support lecturers in a way
resources and keep the required amount of maintenance effort         that they can utilize it within their courses while generating
low.                                                                 as little work overhead as possible (LCR-01). Its primary
                                                                     objective shall be the incorporation of practical programming
B. Deriving Requirements                                             assignments that are also able to integrate software engineering
   We used the observed benefits and shortcomings, identified        concepts or different methods and approaches (LCR-02).
in section II, as a baseline for our requirements. These include        A lecturer should be able to manage course members and
both a selection of important features and functional require-       teams as well as the assignments relevant for the course.
ments. In the following, they are categorized according to their     Therefore, adding, modifying and deleting assignments is re-
appropriate stakeholders, as identified above. The requirements      quired (LCR-03). Available assignments shall be exchangeable
mainly source from our own experience as lecturers, students         between lecturers (LCR-04). In addition, it shall be possible
and admin staff, but we also conducted informal interviews           to provide additional. Course-specific information for an as-
with other lecturers and students to reflect our ideas.              signment (hints, bonus material, links, book recommendations
   1) Students: The platform shall incite the students to solve      on specific topics) (LCR-05). In this context a lecturer shall
the provided assignments by providing interesting/challenging        be able to set limitations on the workflow, e.g. to restrict the
assignments that are either realistic or entertaining or, ideally,   order in which the assignments may be solved or to set timing
both (STD-01). Visual feedback mechanisms shall help to              constraints (LCR-06).
understand the assignments and also guide the workflow
(STD-02). A simple and lightweight on-boarding (registration
and initial orientation) is required for students in order to
minimize the entrance barrier (STD-03). Furthermore, the
platform shall support both pseudonymous (e.g. trough local
user accounts) and personal (e.g. trough university LDAP /
single sign-on) authentication mechanisms to allow students




S. Krusche, S. Wagner (Hrsg.): SEUH 2020                                                                                              30
   Different types of assignments shall be available. These        required so that the platform can not be easily taken over by
shall include at least the following (LCR-07):                     a malicious user.
   • Solo Assignments                                                 Submitted programs and source code assignments also need
        – One student solves the assignment alone.                 to be run independent of each other without any possibility
                                                                   of interaction besides well-defined APIs given by the exer-
   • Competitive Assignments
                                                                   cise (ADM-02). Furthermore, the (repeated) execution of a
        – Solutions of multiple students are compared against      submitted solution must not depend on the state of previous
          each other or put into a competitive scenario.           executions. Consequently, proper environment initialization
   • Collaborative Assignments                                     and clean-up is required (ADM-03).
        – Multiple students work together to create a common          Resources that are available to executed assignments shall
          solution.                                                be limited and it must be possible to stop the execution of
   Orthogonally, assignments can be categorized into               an evaluation or grading task at any given time (ADM-04).
Language-Independent Assignments (LIAs) and Language-              For the sake of resource efficiency, a flawed execution shall
Specific Assignments (LSAs), and both types should be              be detected and stopped as fast as possible (early stopping)
supported by the platform (LCR-08). This includes that LIAs        (ADM-05). This includes pre-execution checks (e.g. static
must be agnostic to the used programming language and              code analysis) as well as runtime checks (e.g. interdependent
therefore grading of a proposed solution can only be done          test cases).
using black-box tests via Standard-IO. In contrast, LSAs can
                                                                             IV. A NALYSIS OF E XISTING PLATFORMS
define various constraints on the source code of a solution
that have to be respected while solving an assignment;                After the identification of our requirements for an advanced
this includes the mandatory use of a specific programming          OPP we systematically analysed existing platforms. We did
language and the mandatory use or the exclusion of a               this with two intentions:
specific language construct. The latter implies the need for a        1) To find out how far these platforms already fulfil our
sophisticated source code analysis tool support that allows to            requirements.
define the necessary white-box tests.                                 2) To get more inspiration and insight on how such plat-
   One of the key benefits of such a platform should be that it           forms can be designed.
allows transparency for the lecturer as well as the students.         Because not all platforms that have been described in publi-
The evaluation criteria should be publicly visible for all         cations are openly available, we could only take a closer look
participants. The passing criteria should be independent of the    at OPPs that are publicly accessible. We further selected the
lecturer and the learning outcome becomes comparable. This         platforms according to their popularity across different scoring
general requirement dictates more specific ones. A lecturer        websites [8], [9] and took different distribution platforms like
shall be able to define evaluation criteria and weigh them         mobile app or websites into consideration. We ended up with
(LCR-09). For example, it shall be possible to reward “clean       seven platforms that we devided roughly into two groups:
code” or a “smart” solution. Another aspect of this requirement    The Introductory OPPs LightBot [10], Edabit [11], and Code-
is that the lecturer shall be able to trace the progress of each   Monkey [12] that are designed for programming beginners;
student on the assignment (LCR-10).                                and the Professional OPPs CodinGame [5], CoderByte [13],
   3) Developer: The requirements of platform developers           HackerRank [14], and CodeWars [15] that target professional
focus on developing, improving and shipping the platform.          programmers. An overview of the analysed platforms and
The platform developer team has to be able to roll out a           some of their properties is given in table I. For the sake
new version or parts of the platform seamlessly without any        of readability and compactness, we merged the identified
interaction by the user (DVL-02). It must also be possible         requirements in Section III into the following criteria:
to run and test individual parts of the platform separately and    Number of Supported Languages: This metric provides a
independent of each other in local test environments or through    fairly good first impression of the capabilities of a platform.
CI-pipelines (DVL-03).                                             Recruiting: Whether the main business case of the platform
   Platform developers furthermore provide an ecosystem for        is recruiting.
assignment developers who shall be able to create and maintain     Competition: Whether solutions by users can compete against
available assignments without the need to get in touch with        each other.
core components of the platform (DVL-04). Created assign-          Visual Feedback: Whether some form of graphical feedback
ments shall be releasable on the platform without modifying        to the user is provided that helps to understand the assignment
the platform code (DVL-05).                                        and supports debugging of the written source code.
   4) Administrators: Administrators define requirements that      Version Control: Whether an external version control system
are primarily important for the operation and back-end design      can be connected to the platform.
of such a platform. For them it is important that the OPP is       Team-play: Whether the platform supports group assignments
self-contained and every execution of untrusted source code is     in any form.
encapsulated inside a sandbox environment, therefore running       Supportive Editor: Whether the editor of the platform offers
independently of the actual platform itself (ADM-01). This is      IDE-like features such as syntax highlighting, auto completion




S. Krusche, S. Wagner (Hrsg.): SEUH 2020                                                                                         31
and search & replace.                                                            Comparing this platform to the requirements in III shows
Code Quality Feedback: Whether the automatic feedback                         that only some of the points match. The platform is easy to
mechanism takes also the quality of the source code of the                    use (STD-01, STD-03) and provides a visualization of the
solution into account, not just its functionality.                            solution and the problem (STD-02). If the user continuously
                                                                              answers wrong, some help text is displayed (STD-05). Due
                                   Table I                                    to the simplicity of the platform other requirements are not
                     C OMPARISON OF SELECTED PLATFORMS                        applicable. For example, it is not possible to produce source
              Platform          L    R     C     F    V     T     S       Q   code with syntax error, because the language consists of
                                                                              predefined building blocks only. The platform is a standalone
              CodeMonkey        1    ⇥     ⇠     X    ⇥     ⇥    X        ⇥
                                                                              application run in a browser or on a mobile device. There is
     Intr.




              Edabit            8    ⇥     ⇥     X    ⇥     ⇥    ⇥        ⇥
              LightBot          1    ⇥     ⇥     X    ⇥     ⇥    ⇥        ⇥   no interaction with others or the server once the application
                                                                              is downloaded and run. All requirements regarding the infras-
              CoderByte        11    X     ⇠     ⇥    ⇥     ⇥    X        ⇥
                                                                              tructure or development are not applicable.
              CodeWars         20    X     X     ⇥    ⇥     ⇥    X        ⇥
     Prof.




              CodinGame        27    X     X     X    ⇥     ⇥    X        ⇥   B. Professional Platforms
              HackerRank       23    X     X     ⇥    ⇥     ⇥    X        ⇥
                                                                                 The professional OPPs are frequently backed and utilized
     L: # supported languages        R: Recruiting       C: Competition       by large companies to identify potential software developers
     F: Visual feedback              V: Version control  T: Team-play
                                                                              for recruiting. They allow for solutions using various program-
     S: Supportive editor            Q: Code Quality feedback
                                                                              ming languages, but are often limited to console based output.
                          ⇥: No     ⇠: Partial    X: Yes                      The only professional OPP that provides pleasing visual feed-
                                                                              back is CodinGame, as shown in figure 1. The complexity of
  Most available OPPs have in common that they provide                        available assignments ranges from simple ones that can easily
easy to use code editors with usability features such as auto-                be completed within 5 minutes to more advanced challenges
completion and syntax error highlighting.                                     including agent behaviour modelling and various algorithmic
A. Introductory Platforms                                                     problems. Furthermore, some platforms also offer exercises
                                                                              targeting specific skills such as regular expressions, for ex-
   Introductory OPPs mainly support only one programming
                                                                              ample found at the HackerRank platform. Professional OPPs
language and typically provide instantaneous and pleasing
                                                                              usually incorporate some sort of competition among users.
visual feedback to the user, as exemplary shown in figure 3.
                                                                              This can be found in the form of global score-boards, user
They offer a low entrance barrier that aims at keeping novice
                                                                              levels, badges, achievement systems, and skill certifications.
programmers motivated. Assignments range from control flow
                                                                              On top of that, some platforms that feature AI programming
handling to basic algorithmic thinking.
                                                                              exercises allow the solutions of multiple users to compete
                                                                              against each other and rank them in a platform wide league
                                                                              system. Moreover, platforms feature regular programming
                                                                              challenges users can take part in and compete against each
                                                                              other. This strong inter-user competition is utilized on most
                                                                              professional OPPs to keep advanced programmers motivated.
                                                                                 The professional platforms are based on basic gamification
                                                                              aspects. The users generally enjoy solving the assignments
                                                                              (STD-01). They are web-based and thus run in a browser
                                                                              (STD-03). CodinGame provides a graphical feedback mecha-
                                                                              nisms (STD-02), the others are only text based. Feedback on
                                                                              syntax errors is provided by the compiler error shown in a
                                                                              console output (STD-07). This is not supportive but at least
                                                                              shows the error. Assisting features of the editors are minimal
             Figure 3. LightBot: user interface with predefined actions       (CodinGame and HackerRank provide code completion (STD-
                                                                              05) and syntax highlighting, some others only only highlight-
   Figure 3 shows the LightBot UI. The goal is to navigate                    ing) or not existing. None of the platforms supports teamwork
the robot to all blue tiles and transform them into yellow                    in any form (STD-09) or a real version control system such
tiles by performing only the actions provided at the bottom                   as git (STD-11), splitting a solution into several text files
of the screen. In the example in Figure 3, the robot can move                 is also not possible (STD-10). The platforms offer ways to
forward, transform a blue tile into a yellow one with the bulb                post a solution into a forum and discuss different approaches
action, turn left or right, and jump. All actions of a solution               (STD-12). On all professional platforms it is possible to create
need to fit into the yellow area on the right side of the screen.             and manage own assignments and support during the creation
All solutions are evaluated in isolation and never compared to                process is offered (LCR-01). Additional information can be
or put into competition with other solutions.                                 provided in the detail description field of each assignment




S. Krusche, S. Wagner (Hrsg.): SEUH 2020                                                                                                    32
(LCR-05). The assignments are available for all users so            pipeline or the execution of the different tasks are discussed
they are exchangeable with others (LCR-04). Other aspects           vaguely. The paper also includes a survey of BotZone in
like restricting certain language features, clean code, different   practice. The platform was used in an AI learning course and
assignment types or forcing specific software engineering           the authors showed that the use of BotZone was fun and also
methods is not possible (LCR-02, LCR-06, LCR-07, LCR-               stressful for a large part of the students.
10). Other requirements for lecturers are not applicable. From         BotZone is an excellent example of a platform that focuses
an administrative and development point of view the platforms       on competing solutions. In the design of any new platform
are commercially used, so the internal features and processes       that is supposed to incorporate competition aspects the lessons
are not publicly available. But the execution of a solution has     learned from this work should be considered.
limited use of resources and execution time (ADM-05).                  3) Kodr: The paper of Amr Draz et al. [19] presents a
                                                                    modular learning platform that combines several features from
C. Further Platforms                                                different other platforms to teach Python programming. Kodr
   During our analysis we discovered further platforms that         helps students to debug their code by using a visualization of
are documented in scientific publications but are not openly        the written code. Students are able to review and replay each
available to the public. Therefore, these could not be included     step the program performs. It also visualizes the memory and
into our detailed analysis. Nonetheless, the platforms depicted     stack usage. In addition, the paper features two surveys on how
below feature novel approaches that we considered noteworthy        to evaluate the use of the platform and its different exercise
and inspirational during our research.                              types.
   1) EasyHPC: Zou et al. [16] created a platform to give              The evaluation method of Kodr can be helpful in examining
students a hand-on experience in high performance computing.        the learning behaviour of students in different assignments.
The most important feature of this platform is that they are        D. Summary
using one of the strongest supercomputers worldwide (Rank
4, June 2019) [17] for their calculations. The platform shall          Even though a lot of inspiration could be found during
be able to support four forms of education: online courses,         this analysis, none of the platforms examined fulfils all our
quiz database, interactive community and a virtual laboratory.      requirements; and we also see no extension path for any of
Online courses are lectures provided by a university or a           the platforms to suit the needs for an OPP complementing
lecturer. The quiz database provides questions for an according     software engineering education. No platform supports collab-
topic. The community shall enable students to discuss their         orative team work or incorporates version control systems
solutions in a forum. The virtual laboratory provides a virtual     (VCS), such as Git or SVN. The lack of such functionality
desktop environment, which can be predefined by teachers            prevents the improvement of many valuable skills a software
to allow for an easy start into an exercise. In the paper,          developer is required to have, such as conducting code reviews
design choices and requirements of students and lecturers           and managing team workflow. Moreover, none of the OPPs
are presented. Students can select online courses offered by        take execution performance, general code quality or software
lecturers and complete both assignments and small tasks             architecture into account when judging a proposed assignment
step-by-step. Teachers can publish new courses, update class        solution. The test verdicts solely depend on whether the
materials and deliver course assignments. One unique feature        submitted programs solve the assignments or not.
of this platform is that it is possible to configure high-                               V. R ELATED W ORK
performance computing environments and upload programs                 Our requirements seem to lighten up a blind spot in the
running in parallel.                                                platform landscape, but several research projects had at least
   Regarding our requirements, this platform is not enough          partly similar goals or tackled problems that also result from
focused on teaching and supporting software engineering.            our requirements.
However, the design process presented in the paper should
be taken into consideration in the design of new platforms.         A. Automated Assessment in a Programming Tools Course
   2) BotZone: BotZone was presented in 2018 by Zhou et                José Luis Fernández Alemán [20] used an automated assess-
al. [18] of Peking University. The platform focuses on studying     ment approach on a programming tools course, which teaches
AI and machine learning. The goal is to design and build a          the use of established tools like make, gcov, gbd or gcc using C
multi-agent game AI platform that is capable of evaluating          as the given programming language. The assessments include
different implementations of game AI by applying them to            testing, debugging, deployment and versioning tasks. Students
various scenarios. The implementations compete against each         are able to access the assignments trough a web based platform
other and achieve ranks in an Elo ranking system. In this           and solve the problems on their own. The solution is then send
way the best approach of the submitted implementations can          to an ”Online Judge” that compiles and executes the program
be evaluated. Students are able to write their solutions in         with predefined input cases. The results get analysed and a
different languages, such as C/C++, Java, C# JavaScript, or         feedback is generated for the student notifying if the program
Python. The main focus of the platform is the competitive           is correct or not.
aspect. Therefore, the structure and architecture is optimized         This is a very basic approach but is underlined with a case
to achieve this goal. Detailed technical information on the         study of 46 participants showing that this approach lead to




S. Krusche, S. Wagner (Hrsg.): SEUH 2020                                                                                          33
better results comparing to the learning outcome participants      system analyses student assignments and generate automated
who were trained in a traditional way. This paper shows            feedback on the used identifier names. A survey shows that
that even basic assistance in programming education helps to       this can help to improve the code quality of the assignments
improve the learning outcome for students.                         and enhances the readability of the code in contrast to manual
                                                                   reviews by lecturers. The first step is a normalization of
B. The BOSS Online Submission and Assessment System
                                                                   the assignment description and extract a reference vocabulary
   Joy et al. [21] use a more complex approach for an online       from it. This step contains normalization, tokenization and
assessment system. They identified three fundamental compo-        stemming techniques. In the second phase, the identifier names
nents for an assessment. The first being the correctness of the    in the source code are estimated in a mapping to the words in
solution. This is defined by the specification of the assignment   the vocabulary. Words that can not be mapped to a vocabulary
and is checked by black and white box tests. The second            entry are considered to be inappropriate and a warning is
component is the style, which they sub-classify in two parts,      created to signal the students to reconsider the identifier name.
language independent and language specific characteristics.        In a case study also presented in the paper this leads to an
Independent features are for example efficiency of the program     accuracy of 75% compared with a manual assessment by the
or the choice of an algorithm used. Among others, Language         lecturers.
specific features are the code structure or the use of external       This paper presents useful techniques and methods for per-
libraries. The last component, authenticity, describes tasks of    forming analyses of non-functional characteristics of student
organizational nature such as managing the users, verifying        source code. The approaches used for normalization of source
the identity of users and checking for plagiarism. The paper       code and the deduction of code quality can be used in future
shows which requirements can be derived from different user-       systems.
groups interacting with the platform for example the staff and
the students. These requirements define different views of the                           VI. C ONCLUSION
system, which dictate the basic architecture and the individual       Online programming platforms provide vast opportunities
components inside the system.                                      for individuals to develop and improve their programming
   In comparison to the requirements presented in this work,       skills. In this paper, we showed that many platforms feature
some are in common and the lessons learned can be reused,          novel approaches that provide users with modern and highly
for others, such as teamwork or version control and manage-        motivational game-based programming assignments. But none
ment, new approaches have to be developed. The detection           of the available platforms addresses essential software engi-
of plagiarism, a core requirement in the BOSS system, is           neering aspects such as code quality, maintainability, adequate
deliberately excluded from our requirements. We think that         program architecture, team based programming, or code re-
the focus on platforms that provide helpful, non-mandatory         views.
additional resources for learners reliefs from many problems          Based on our experience gathered from successfully us-
formal grading systems have to face.                               ing the CodinGame platform within a bachelor project, we
C. Towards Practical Programming Exercises and Automated           proposed requirements for an OPP that better complements
Assessment in Massive Open Online Courses                          software engineering education. We assume that an OPP, when
                                                                   developed with respect to these requirements, can significantly
   Staubitz et al. [22] state several benefits and shortcomings
                                                                   raise the quality of teaching and be beneficial for both students
of different approaches of designing an online programming
                                                                   and lecturers.
platform for massive user use. They concluded that they need
                                                                      In future work we aim at creating a platform prototype
a flexible solution that can handle different scenarios based
                                                                   which is based on the proposed requirements and at evaluating
on the expertise of the course. Programming beginners prefer
                                                                   it with students in software engineering courses. Gathered
a web based editor where no set up is required. Advanced
                                                                   feedback will be used to refine the requirements and improve
users favour development tools used on their own machine.
                                                                   the created platform. A long term goal is to establish such
The presented platform consists of an automated testing suite
                                                                   an online programming platform in the BCS degrees at the
that can check the given solution with a number of different
                                                                   HAW Hamburg as an assistance in all programming-related
tests on unit and acceptance level. This paper conquers issues
                                                                   modules.
we also identified as relevant in our requirements, such as
scaling the application and modifying it on demand, depending
on the course and the experience of the students. The results
can help to improve strategies dealing with those issues in
future systems.
D. Giving Automated Feedback About Student Code Identi-
fiers: a Method Based on the Description of Programming
Problem
   Nascimento et al. [23] presented a system that can help
programmers to improve the readability of their programs. The




S. Krusche, S. Wagner (Hrsg.): SEUH 2020                                                                                          34
                            R EFERENCES                               [13] Coderbyte, [Online]. Available: https://coderbyte.com/
 [1] M. Papastergiou, “Digital Game-Based Learning in high                 (visited on 10/15/2019).
     school Computer Science education: Impact on educa-              [14] HackerRank, [Online]. Available: https : / / www .
     tional effectiveness and student motivation”, Computers               hackerrank.com/ (visited on 10/15/2019).
     & Education, vol. 52, no. 1, pp. 1–12, 2009, ISSN: 0360-         [15] CodeWars, [Online]. Available: https://www.codewars.
     1315. DOI: https://doi.org/10.1016/j.compedu.2008.06.                 com/ (visited on 10/15/2019).
     004. [Online]. Available: http://www.sciencedirect.com/          [16] Z. Zou, Y. Zhang, J. Li, X. Hei, Y. Du, and D.
     science/article/pii/S0360131508000845.                                Wu, “EasyHPC: An Online Programming Platform for
 [2] A. Schmolitzky, “Zahlen, Beobachtungen und Fra-                       Learning High Performance Computing”, in 2017 IEEE
     gen zur Programmierlehre”, in Tagungsband 15.                         6th International Conference on Teaching, Assessment,
     Workshop ”Software Engineering im Unterricht der                      and Learning for Engineering (TALE), Dec. 2017,
     Hochschulen”, 2017, pp. 83–90. [Online]. Available:                   pp. 432–435. DOI: 10.1109/TALE.2017.8252374.
     http://ceur-ws.org/Vol-1790/paper10.pdf.                         [17] TOP500 List - June 2019 Supercomputers, [Online].
 [3] D. I. K. Sjoeberg, J. E. Hannay, O. Hansen, V. B.                     Available: https://www.top500.org/list/2019/06/ (visited
     Kampenes, A. Karahasanovic, N. .-.-. Liborg, and A. C.                on 10/29/2019).
     Rekdal, “A Survey of Controlled Experiments in Soft-             [18] H. Zhou, H. Zhang, Y. Zhou, X. Wang, and W. Li,
     ware Engineering”, IEEE Transactions on Software                      “Botzone: An Online Multi-agent Competitive Platform
     Engineering, vol. 31, no. 9, pp. 733–753, Sep. 2005.                  for AI Education”, in Proceedings of the 23rd Annual
     DOI : 10.1109/TSE.2005.97.                                            ACM Conference on Innovation and Technology in
 [4] T. Hinrichs and A. Schmolitzky, “Einbindung einer                     Computer Science Education, ser. ITiCSE 2018, Lar-
     Online-Programmierplattform in die Präsenzlehre – ein                 naca, Cyprus: ACM, 2018, pp. 33–38, ISBN: 978-1-
     Erfahrungsbericht”, in Proceedings of the Fourth Work-                4503-5707-4. [Online]. Available: http://doi.acm.org/
     shop "Automatische Bewertung von Programmierauf-                      10.1145/3197091.3197099.
     gaben" (ABP 2019), Essen, Germany, October 8-9,                  [19] A. Draz, S. Abdennadher, and Y. Abdelrahman, “Kodr:
     2019, Gesellschaft für Informatik e.V., 2019. DOI: 10.                A Customizable Learning Platform for Computer Sci-
     18420/abp2019-8.                                                      ence Education”, in Adaptive and Adaptable Learning,
 [5] CodinGame, [Online]. Available: https : / / www .                     K. Verbert, M. Sharples, and T. Klobučar, Eds., Cham:
     codingame.com/ (visited on 10/15/2019).                               Springer International Publishing, 2016, pp. 579–582,
 [6] M. Kölling, “The Greenfoot Programming Environ-                       ISBN : 978-3-319-45153-4.
     ment”, Trans. Comput. Educ., 14:1–14:21, Nov. 2010,              [20] J. L. Fernandez Aleman, “Automated Assessment in
     ISSN : 1946-6226. [Online]. Available: http://doi.acm.                a Programming Tools Course”, IEEE Transactions on
     org/10.1145/1868358.1868361.                                          Education, vol. 54, no. 4, pp. 576–581, Nov. 2011,
 [7] N. Gandraß and A. Schmolitzky, “Automatisierte Be-                    ISSN : 1557-9638. DOI : 10.1109/TE.2010.2098442.
     wertung von Java-Programmieraufgaben im Rahmen                   [21] M. Joy, N. Griffiths, and R. Boyatt, “The Boss Online
     einer Moodle E-Learning Plattform”, in Proceedings                    Submission and Assessment System”, J. Educ. Resour.
     of the Fourth Workshop "Automatische Bewertung von                    Comput., vol. 5, no. 3, Sep. 2005, ISSN: 1531-4278.
     Programmieraufgaben" (ABP 2019), Essen, Germany,                      DOI : 10 . 1145 / 1163405 . 1163407. [Online]. Available:
     October 8-9, 2019, Gesellschaft für Informatik e.V.,                  http://doi.acm.org/10.1145/1163405.1163407.
     2019. DOI: 10.18420/abp2019-1.                                   [22] T. Staubitz, H. Klement, J. Renz, R. Teusner, and
 [8] The 10 most popular coding challenge websites for                     C. Meinel, “Towards practical programming exercises
     2020, [Online]. Available: https://www.freecodecamp.                  and automated assessment in Massive Open Online
     org / news / the - 10 - most - popular - coding -                     Courses”, in 2015 IEEE International Conference on
     challenge-websites-of-2016-fb8a5672d22f/ (visited on                  Teaching, Assessment, and Learning for Engineering
     10/29/2019).                                                          (TALE), Dec. 2015, pp. 23–30. DOI: 10. 1109/ TALE.
 [9] The 10 Best Coding Challenge Websites for 2018,                       2015.7386010.
     [Online]. Available: https : / / medium . com / coderbyte /      [23] D. S. Marcos Nascimento Eliane Araújo, “Giving Au-
     the - 10 - best - coding - challenge - websites - for - 2018 -        tomated Feedback About Student Code Identifiers: a
     12b57645b654 (visited on 10/29/2019).                                 Method Based on the Description of Programming
[10] LightBot, [Online]. Available: https : / / lightbot . com/            Problem”, in Anais do SBIE 2019 (Proceedings of the
     (visited on 10/15/2019).                                              SBIE 2019), 2019. DOI: 10.5753/cbie.sbie.2019.537.
[11] Edabit, [Online]. Available: https://https://edabit.com/
     (visited on 10/15/2019).
[12] CodeMonkey - Coding for Kids, [Online]. Available:
     https://www.codemonkey.com/ (visited on 10/15/2019).




S. Krusche, S. Wagner (Hrsg.): SEUH 2020                                                                                          35