Skip to content

lukaszdobosz/JAlgoArena

 
 

Repository files navigation

JAlgoArena Build Status JProfiler

JAlgoArena is a programming contest platform. You can use it in SaaS mode (e.g. Heroku) as well as on-premises (self-hosted) mode - which is great alternative to portals like HackerRank and others - when you are limited to only own infrastructure or you just don't want to pay for external service or help in organizing coding contest for your developers.

JAlgoArena itself is implemented as set of microservices, based on Spring Boot and hosted (in SaaS mode) on Heroku.

Demo

As JAlgoArena DEMO is hosted on free heroku account - they are goes every 5 minute sleep. If you want to successfully check below demo - firstly make sure you can open all below links to wake up all services

Demo: https://jalgoarena-ui.herokuapp.com/

Introduction

  • JAlgoArena allows user to see existing problems, create account and using it submit solutions for existing problems, in one of two languages: Kotlin and Java. Every solution is limited by time and memory consumption and needs to pass all defined test cases. Problems itself are divided into three difficulty levels for each ones receiving different set of points. Additionally Kotlin language is promoted, giving you 150% of usual points in Java with same time.
  • JAlgoArena conduts many parts, coming from Web UI, going through API service, which finally reaches direct parts of JAlgoArena: Judge Engine for Kotlin and Java, Authentication & Authorization Service keeping info about Users, Problems Service holding definition and meta-data about avialable problems and finally Submissions Service, where submissions are stored and ranking is calculated. Finally - all of that behind of scene is orchestrated by Eureka (discovery service) - which allows on loosely coupling between services and easy way to scale them

Component Diagram

Components

Kanban Board

JAlgoArena kanban board showing planned features and their development progress.

Kanban Board

State Priority Description
Ideas Unset Not yet decided if they will be done
Backlog Low To be done
TODO High Will be done for the next releases
In Progress High Features in progress
Done High Features implemented and released

E2E Tests

  • end to end tests written in spock
  • it runs against deployed applications (Heroku)
  • it covers 2 cases, 1st for Java and 2nd for Kotlin

Continuous Delivery

  • initially, developer push his changes to GitHub
  • in next stage, GitHub notifies Travis CI about changes
  • Travis CI runs whole continuous integration flow, running compilation, tests and generating reports
  • coverage report is sent to Codecov
  • application is deployed into Heroku machine

Continuous Delivery

Infrastructure

Running locally

To see detailed instructions on how to run particular components - go to below pages and look for running locally section. Below order is important if you want UI to be fully functional just after starting. Although - you can start it in any order - having some parts of functionallity not working till all parts will be started.

Developing new Judge Agent

  • If you would like to develop new judge agent supporting new programming language, or using different approach for judgement - please follow instructions in here: how to develop new judge agent

Notes

Component Diagram

About

JAlgoArena programming contest platform

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Java 43.5%
  • Kotlin 41.2%
  • Groovy 15.3%