Skip to content

Latest commit

 

History

History
100 lines (70 loc) · 3.69 KB

README.md

File metadata and controls

100 lines (70 loc) · 3.69 KB

DAS Client

DAS (Driver Advisory System) is a mobile application that provides all the required journey data to the train driver.

Supported platforms

Android iOS

Build and run

DAS Client has 3 distinct flavors: dev, inte and prod. Run them as follows:

fvm flutter run --flavor dev -t lib/main_dev.dart
fvm flutter run --flavor inte -t lib/main_inte.dart
fvm flutter run --flavor prod -t lib/main_prod.dart

Running Integration Tests

Instrumentation Tests do not use user authentication. Therefore the credentials must be provided as environment variables.

fvm flutter test --flavor dev --dart-define=MQTT_USERNAME=${MQTT_USERNAME} --dart-define=MQTT_PASSWORD=${MQTT_PASSWORD} integration_test/app_test.dart

Architecture

Test file structure

To prevent confusion, fictive train numbers with the prefix T are used for the test scenarios. It is desired to create new train journeys for different features.
The file structure in test_resources for a test scenario looks as follows:

  • base directory named <train number>_<optional description>
  • journey profile named SFERA_JP_<train number>_<optional postfix>
  • corresponding segment profiles named SFERA_SP_<train number>_<segment number>
  • corresponding train characteristics named SFERA_TC_<train number>_<tc number>
    An example test scenario for train number T1 could look like this:
  • T1_demo_journey/
    • SFERA_JP_T1
    • SFERA_JP_T1_without_stop
    • SFERA_SP_T1_1
    • SFERA_SP_T1_2
    • SFERA_TC_T1_1

Localization

The app is available in three languages:

German French Italian

Localization terms/keys conform to the following format:

<PREFIX>_<CONTEXT?>_<LABEL>

The prefix is mandatory and indicates the scope of the term. Valid prefixes are:

Prefix Scope Description
c Common Common terms that can be used in the whole app
p Page Terms that belong to a specific page
w Widget Terms that bleong to a specific widget

The context is optional and indicate where a localization is used. When a localization is scoped to a page or widget, the context MUST be equal to the name of that page or widget. For example, localizations used on the login page would start with p_login_.

To generate the localization code, run the following command:

fvm flutter gen-l10n

Code style

This application uses the code style defined in the Flutter Wiki. The recommendations are mandatory and should always be followed unless there is a good reason not to do so. However, this must be approved by all developers.

Notable difference: Line length is set to 120 characters. Please adapt your IDE configuration accordingly.

Flutter SDK version

This app uses FVM to configure the Flutter SDK version.