Skip to content

Baeldung/scala-tutorials

Folders and files

NameName
Last commit message
Last commit date
Jul 5, 2024
Jun 23, 2023
Feb 25, 2025
May 15, 2024
Apr 11, 2025
Mar 18, 2025
May 14, 2024
Mar 18, 2025
Mar 18, 2025
May 20, 2024
May 19, 2024
Nov 15, 2024
Nov 26, 2024
Nov 5, 2024
Jan 12, 2025
May 18, 2024
Mar 18, 2025
Mar 18, 2025
Jun 27, 2024
Jan 20, 2025
Jan 23, 2025
Oct 17, 2024
May 14, 2024
Oct 12, 2024
Dec 8, 2023
Nov 27, 2024
Apr 11, 2025
May 25, 2024
Mar 14, 2025
Dec 8, 2023
Dec 7, 2023
Mar 18, 2025
May 18, 2024
Nov 26, 2024
May 15, 2024
May 14, 2024
May 18, 2024
Apr 11, 2025
Mar 19, 2025
May 14, 2024
Sep 6, 2023
Sep 27, 2024
May 18, 2024
May 14, 2024
Oct 25, 2023
Jun 27, 2024
Dec 20, 2023
Nov 3, 2023
Oct 25, 2023
Jul 5, 2024
Nov 30, 2019
Nov 1, 2023
Oct 1, 2023
Apr 13, 2025
Feb 1, 2023
May 16, 2024

Repository files navigation

Scala Steward badge

scala-tutorials

This is the main repo for all the sample code used in the scala tutorials.

Pre-requisites

Suggested JDK version : JDK 17

Compiling and Running Tests

This repo uses a multi-module build with many sub modules. To compile the entire module, you may use the command sbt compile. However, this loads all the modules and compiles all of them, which might take some time. If you are interested in only a particular module, you can compile it by starting sbt shell and using the command <sub-module-name>/compile. Similarly, you can run the tests per module as <module-name>/test.

Here are some of the useful commands that can be used within tbe sbt shell

SBT Command Description Example
project <sub-module-name> Switch to a particular module. After this, the command compile, test etc runs only on that module project scala_core
<sub-module-name>/compile Compile only the provided module scala_core/compile
projects Lists all the sub modules
<sub-module-name>/run Run the main class within the sub-module scala_core/run

Note: The project name may not be same as directory name. Instead, it is the lay val variable used to define each module

Test Naming Standards

In this repository, we have classified the tests in 4 categories.

Category Description
Unit Tests Smallest unit of testing, that are not dependent on external tools or services
Integration Tests IntegrationTests means those tests that use some automatic setup within our environment like in-memory Mongo, h2 database etc which don't need explicit setup
Live Tests Tests that depends on some external services (like httpbin.org, or some internet-based links) or require a running component (eg: starting a Spring Boot application)
Manual Tests The tests where we need to set up an environment explicitly(for e.g. docker), without which the tests can't be run

Here is a table describing about the different categories of tests and how they can be executed in this project. Note that these commands are defined at the root level of the project and hence are accessible only from the root project(not directly within each submodule).

Category Sbt command Test class location Test class name format
Unit Tests sbt ci src/test/scala or src/test/scala-2 No particular format restriction, but as a standard, filename ends with Test
Integration Test (Only) sbt integrationTests src/it/scala or src/it/scala-2 No format restriction, but as a standard, filename ends with IntegrationTest
Unit & Integration Test sbt ciFull src/it/scala or src/it/scala-2 No format restriction, but as a standard, filename ends with IntegrationTest. These exclude manual and live tests
Live Test sbt liveTests src/it/scala or src/it/scala-2 Test class name must end with LiveTest
Manual Test sbt manualTests src/it/scala or src/it/scala-2 Test class name must end with ManualTest

Code formatting

Before creating a PR, run sbt scalafmtAll to automatically format the entire codebase. To check if there are any formatting issues(without fixing them), you may run sbt scalafmtCheckAll