Skip to content

Commit

Permalink
SW5 (#177)
Browse files Browse the repository at this point in the history
* .

* Implemented syntax check

* Fork'ed protobuf repo (#6)

* Removed old protobuf submodule

* Added new forked protobuf submodule

* Fix workflow

* cleaned up the jobs and replaced the actions with newer non-deprecated versions

* fixed clippy check and modified the run cargo to use an action instead

* fix workflow dispatch

* modifed to do on push rather than PR

* tried another Clippy

* go back to previous clippy action

* fixed problems mentioned from Clippy

* Add install instructions for linux and windows

* Convert triple slash comments into normal EoL comments

* Convert EoL comments to triple slash comments

* Fix typos in documentation comment on state

* add warnings for non snakecase names

* Fix snake case naming in tests

* fixed upload-artifact. Retention days reduced from 90 to 7 days

* Rename constraint applyer to constraint applier

* Remove datatypes and move statepair list into model objects

* Move decision.rs into modelobjects

* Fix more snake name cases in tests

* Update workflows

* Run cargo format

* Fix clippy warnings for module name 'conjunction_tests':

* Added cache utilization

* Updated protobuf submodule pointer

* Formatted code

* Component cache unit tests

Tests for when a component exists in cache and when it does not.

* Cargo formatting

* Raffineret vores implementation af syntaks tjek

* Vi har lige kørt cargo fmt

* Renamed variable

Renamed a variable to be more self-explanatory.

* Add syntax tests

* cargo fmt

* Fix syntax failure test

* Apply suggestions from code review

Co-authored-by: Rasmus Krogh Udengaard <[email protected]>
Co-authored-by: Ali Khorami <[email protected]>
Co-authored-by: Animal2662 <[email protected]>

* delay_refinement rename tests to be snakecase

* conjunction_tests.rs rename tests to be snakecase

* Test between different users and cache

* Merged main

* formatting

* Remove debug backtrace

* Add SyntaxFailure server response

* Protobuf changes

* Starting grpc server -> Started grpc server
also changed info to println to avoid the debugger for now

* Update submodule pointer

* Structure of symboltable for clocks implemented

* Small fixes to the ClockScope structure. Added next task description at the relevant lines of code in extract_system_rep.rs file

* First draft for code to find clocks, has errors as of this moment

* Fixed problems with the new scope structure missing derive implementations. Also fixed some missing implementation of the new clocks HashMap for component. Fixed small bug related to Private/Public mismatch

* Changed clock scope struct to new format. Renamed it aswell

* Worked on logic for creating and populating clock_usages

* Fixed errors in Initialisation logic and iterator logic for the work on clock scopes

* More logic added for the get_clocks boolean and arithmetic helper functions. Also refactored them a bit to save space

* Marked useless parameters with (_)

* started writing tests for finding clocks in bool and arith expressions

* Refactor boolexpression & arithexpression. Ref is replaced.

* Work on ClockUsage population logic(clock scopes). Work on tests for said logic

* Added TODO descriptions

* Logic for populating ClockUsage struct without duplicates should be complete. Pushing to github so i can compile from (working)laptop

* Unit testing on get_clocks_arith & get_clocks_bool succesful-6

* Unit testing on get_clocks_arith & get_clocks_bool succesful-6

* Changes by tordenguden emil

* Fixed bugs related to Ownership/references

* Added back accidentally deleted tests

* Fixup modules

* Moved get_var_names functions for Bool and arith expression from extract_system_rep to their respective files(bool_expression, Arith_expressions). Moved their associated tests into them aswell.

* Renamed varname to var_name

* Move vec creation logic

* Implemented HashSet for ClockUsage struct instead of HashMap.

* Implemented add and get methods on CloclUsage struct.

* Moved populate ClockUsage struct logic, into seperate functions to increase readability and modularity

* Removed redundant comments

* intermediate commit. started working on tests for populating components

* forgot a file

* Fixed creation of test component. Added default to Edge and Location

* Back with project_loader for unit/integration testing. Fixed Default in edge.rs and location.rs

* skips de-serializing clock_usages in component struct

* breakthrough, figured out how the function we are testing works -6

* added two test_cases for populate_usages_with_guards

* wrote tests for the populate_usages_with_locations and populate_usages_with_updates functions

* renamed populate_usages_with_locations to populate_usages_with_invariants to better reflect functionality

* moved logic shared between the tests into a setup function. is maybe more complicated than previous solution

* fixed warnings when during build

* added tests for populating usages with updates on rhs. also created new sample project for the tests. also added comments to the tests

* Refactored initialisation of component

* removed redundant comments

* fixed refactoring to make it build, also fixed som warnings

* refactored populate tests to use method for initialising clock usages

* added single test for the initialise_clock_usage method

* added single test for the initialise_clock_usage method

* small things

* moved populate tests to component.rs since the methods tested were moved her previously

* Added templates for the current missing function implementations for component. Templates include comments describing function purpose and warnings for the implementation.

 These implementations possible should be moved into the SystemRecipe instead of component.

* Commented out previous task deskriptions as they are now no longer correct. Begun to add new task descriptions, which may loan elements from the commented

* Updated all the new task descriptions and removed old completly

* removed unused crate

* Modified actions task, to reflect this task actually may be redundant

* Prepared for implementing clock reduction, mostly just a sync to cloud with non working code.

* Use `Rc<OwnedFederation>` for zones in `StatePair`

* Use reference counting for `LocationTree` in `StatePair`

* Make the `zone` of a `State` consistent with `StatePair`

* Fix clippy errors

* Cleanup

* Worked on two seperate ideas to solve the issue of clockReduction on component. None are done as of now and the commit has non-working code

* Fix partial state test

* Completed logic for updating global equivalent clock groups and implemented method for extracting int value for arithmetic expressions.

* Further progress on remove_redundant_clocks

* fix

* Further progress on remove_redundant_clocks and associated functions

* Final changes to system recipe. Relocated clock_usage initialisation/decoration into component_loader. Also removed old calls to clock_reduce

* Added compress declarations method to component.

* Implemented clock_reduction in component loading

* Bug-fixes. fixed errors from component when building.

* Back with project_loader for unit/integration testing. Fixed Default in edge.rs and location.rs

* Re-commit

* Changes by tordenguden emil

* Diabled CR for reachability queries. To avoid test issues in two cases

* Error propogations added to local equivalence

* Test templates and a new sample added. First new test done.

* added test for update_global_groups

* Compress_dcls test completed

* added test for get_evaluated_int method with multiple test cases

* Get_unused_clocks test completed and ran cargo fmt... oh god, why?

* Test for find_local_equivalences created

* Merge get_unused_clocks with find_local_equivalences

* Unfinished attempt to fix find_equivalent_clock_groups test

* Identified error in testcase setup for find_equvialnt_clockgroups

* created test for complete component-side clock reduction

* disabled clock reduction on clock scope related tests, and did some formatting of the tests

* added a few comments for some of the tests

* cargo fmt and clippy

* resolved some build warnings, mostly unnecessary mut variables

* removed unused methods and tests for previous implementation of clock reduction

* dealt with more warnings

* added todo for figuring out why tests fail

* fixed multiple tests failing

* Refactored a bit of code to avoid cloning and made some small changes generelly to improve readability. Also introduced new ErrorTypes

* Fixes and refactoring

* updated start_grpc_server to align with main, which enables us to run Ecdar-Test

* Updated some comments

* Cargo formatting

* Clippy fixes

* small fix

* Update submodule reference

* Fixed error in tests arisen from the new Errorhandlings merged from main (Syntax errors)

* Cargo format

* Update src/data_reader/component_loader.rs

Co-authored-by: FrederikJA <[email protected]>

* Update src/model_objects/component.rs

Co-authored-by: FrederikJA <[email protected]>

* Update src/model_objects/component.rs

made it clear that we're using the function called setup

Co-authored-by: Rasmus Krogh Udengaard <[email protected]>

* Update src/model_objects/component.rs

Co-authored-by: Rasmus Krogh Udengaard <[email protected]>

* Update src/model_objects/component.rs

Co-authored-by: Rasmus Krogh Udengaard <[email protected]>

* Apply suggestions from code review

grammar fixes

Co-authored-by: Rasmus Krogh Udengaard <[email protected]>

* requested changes

* cargo fmt..

* updated get_clock_count method to count unique clock indices

* Test to make sure unused clocks are removed correct

* Clippy

* Clippy

* Apply suggestions from code review

applied grammar changes

Co-authored-by: Ali Khorami <[email protected]>

* Delete samples/json/EcdarUniversity/Components/Researcher2.json

This file should not have been commited

* gitignore updated

* Delete samples/json/PopulateClocks/Components/Researcher2.json

* Revert "Delete samples/json/PopulateClocks/Components/Researcher2.json"

This reverts commit e62f558.

---------

Co-authored-by: sabotack <[email protected]>
Co-authored-by: William Woldum <[email protected]>
Co-authored-by: Aavild <[email protected]>
Co-authored-by: aavild <[email protected]>
Co-authored-by: FrederikJA <[email protected]>
Co-authored-by: williamwoldum <[email protected]>
Co-authored-by: Rasmus Hald Nielsen <[email protected]>
Co-authored-by: Rasmus Krogh Udengaard <[email protected]>
Co-authored-by: Ali Khorami <[email protected]>
Co-authored-by: Animal2662 <[email protected]>
Co-authored-by: mikkelklitlund <[email protected]>
Co-authored-by: Rasmus Hald Nielsen <[email protected]>
Co-authored-by: Erik <[email protected]>
Co-authored-by: AleksanderRDL <[email protected]>
Co-authored-by: Emilorzz <[email protected]>
Co-authored-by: AleksanderRDL <[email protected]>
Co-authored-by: Simon Rask <[email protected]>
Co-authored-by: Simon Rask <[email protected]>
Co-authored-by: Emilorzz <[email protected]>
  • Loading branch information
20 people authored Feb 12, 2024
1 parent b338fa2 commit 60bbb2a
Show file tree
Hide file tree
Showing 162 changed files with 5,883 additions and 3,079 deletions.
73 changes: 31 additions & 42 deletions .github/workflows/build_artifacts.yaml
Original file line number Diff line number Diff line change
@@ -1,95 +1,84 @@
name: Build artifacts
name: Build Artifacts

on:
pull_request:
branches:
- main
workflow_dispatch:
push:

jobs:
build-macos:
macos:
name: Build MacOS
runs-on: macos-latest
steps:
- uses: actions/checkout@v3
with:
submodules: 'true'
- uses: arduino/setup-protoc@v1.1.2
- uses: arduino/setup-protoc@v2
with:
repo-token: ${{ secrets.GITHUB_TOKEN }}
- uses: actions-rs/toolchain@v1
with:
profile: minimal
toolchain: stable
override: true
- uses: dtolnay/rust-toolchain@stable
- uses: Swatinem/rust-cache@v2
with:
cache-on-failure: true
- name: Build
uses: actions-rs/cargo@v1
- name: cargo build --release
uses: clechasseur/rs-cargo@v1
with:
command: build
args: --release
- name: Upload artifacts
uses: actions/upload-artifact@v2
- uses: actions/upload-artifact@v3
with:
name: reveaal-macos
path: target/release/Reveaal
path: target/release/reveaal
if-no-files-found: error
retention-days: 7

build-win:
win:
name: Build Windows
runs-on: windows-latest
steps:
- uses: actions/checkout@v3
with:
submodules: 'true'
- uses: arduino/setup-protoc@v1.1.2
- uses: arduino/setup-protoc@v2
with:
repo-token: ${{ secrets.GITHUB_TOKEN }}
- uses: actions-rs/toolchain@v1
with:
profile: minimal
toolchain: stable
override: true
- uses: dtolnay/rust-toolchain@stable
- uses: Swatinem/rust-cache@v2
with:
cache-on-failure: true
- name: Build
uses: actions-rs/cargo@v1
- name: cargo build --release
uses: clechasseur/rs-cargo@v1
with:
command: build
args: --release
- name: Upload artifacts
uses: actions/upload-artifact@v2
- uses: actions/upload-artifact@v3
with:
name: reveaal-windows
path: target/release/Reveaal.exe
path: target/release/reveaal.exe
if-no-files-found: error

build-ubuntu:
retention-days: 7

ubuntu:
name: Build Ubuntu
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
with:
submodules: 'true'
- uses: arduino/setup-protoc@v1.1.2
- uses: arduino/setup-protoc@v2
with:
repo-token: ${{ secrets.GITHUB_TOKEN }}
- uses: actions-rs/toolchain@v1
with:
profile: minimal
toolchain: stable
override: true
- uses: dtolnay/rust-toolchain@stable
- uses: Swatinem/rust-cache@v2
with:
cache-on-failure: true
- name: Build
uses: actions-rs/cargo@v1
- name: cargo build --release
uses: clechasseur/rs-cargo@v1
with:
command: build
args: --release
- name: Upload artifacts
uses: actions/upload-artifact@v2
- uses: actions/upload-artifact@v3
with:
name: reveaal-ubuntu
path: target/release/Reveaal
if-no-files-found: error
path: target/release/reveaal
if-no-files-found: error
retention-days: 7
45 changes: 45 additions & 0 deletions .github/workflows/check_format.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@
name: Check formatting

on:
workflow_dispatch:
push:

jobs:
fmt:
name: cargo fmt
runs-on: ubuntu-latest
steps:
- run: sudo apt-get install llvm protobuf-compiler
- uses: actions/checkout@v3
with:
submodules: 'true'
- uses: dtolnay/rust-toolchain@stable
with:
components: rustfmt
- uses: Swatinem/rust-cache@v2
with:
cache-on-failure: true
- name: cargo fmt --all
uses: clechasseur/rs-cargo@v1
with:
command: fmt
args: --all -- --check

clippy:
name: Clippy lint and check
runs-on: ubuntu-latest
steps:
- run: sudo apt-get install llvm protobuf-compiler
- uses: actions/checkout@v3
with:
submodules: 'true'
- uses: dtolnay/rust-toolchain@stable
with:
components: clippy
- uses: Swatinem/rust-cache@v2
with:
cache-on-failure: true
- name: clippy --all-targets --all-features
uses: clechasseur/rs-clippy-check@v3
with:
args: --all-targets --all-features -- -D warnings
61 changes: 0 additions & 61 deletions .github/workflows/ci.yaml

This file was deleted.

25 changes: 25 additions & 0 deletions .github/workflows/run_tests.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
name: Run Tests

on:
workflow_dispatch:
push:

jobs:
ubuntu:
name: Tests Ubuntu
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
with:
submodules: 'true'
- run: sudo apt-get install llvm protobuf-compiler
- uses: dtolnay/rust-toolchain@stable
with:
components: clippy
- uses: Swatinem/rust-cache@v2
with:
cache-on-failure: true
- name: cargo test
uses: clechasseur/rs-cargo@v1
with:
command: test
3 changes: 1 addition & 2 deletions .gitmodules
Original file line number Diff line number Diff line change
@@ -1,4 +1,3 @@
[submodule "Ecdar-ProtoBuf"]
path = Ecdar-ProtoBuf
url = https://github.com/Ecdar/Ecdar-ProtoBuf.git
branch = main
url = https://github.com/ECDAR-AAU-SW-P5/Ecdar-ProtoBuf.git
2 changes: 1 addition & 1 deletion Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ name = "reveaal"
path = "src/lib.rs"

[[bin]]
name = "Reveaal"
name = "reveaal"
path = "src/main.rs"

[features]
Expand Down
2 changes: 1 addition & 1 deletion Ecdar-ProtoBuf
Submodule Ecdar-ProtoBuf updated 1 files
+15 −4 query.proto
33 changes: 20 additions & 13 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,25 +6,32 @@ This is a model checking engine for ECDAR (Environment for Compositional Design
#### DBM Library
The engine uses the ECDAR DBM Library for operations on zones of time (https://www.github.com/ECDAR/EDBM).

## Prerequisites
## Building

### Prerequisites
- A rust compiler installed (https://www.rust-lang.org/learn/get-started)
- A folder containing the model components to check
- Download ProtoBuf definitions with ```git submodule update --init --recursive```

### Compiling on Linux
You may need the ProtoBuf compiler protoc (for the Ubuntu linux distribution ```apt install protobuf-compiler```)
**Windows**:
We recommend installing and using the default ```x86_64-pc-windows-msvc``` Rust targets.
If you instead (not recommended) are using ```x86_64-pc-windows-gnu``` targets on Windows you need to install mingw and add it to your PATH variable to build.

#### Protobuf
**Debian based (Ubuntu, mint etc.)**: ```apt install protobuf-compiler```

**Arch based (Endeavour etc.)**: ```yay protobuf-c```

### Compiling on Windows
We recommend installing and using the default `x86_64-pc-windows-msvc` Rust targets.
If you instead (not recommended) are using `x86_64-pc-windows-gnu` targets on Windows you need to install mingw and add it to your PATH variable to build.
**Windows**: Download protobuf (https://github.com/protocolbuffers/protobuf/releases/)
Add the bin folder to your path environment variable (https://www.computerhope.com/issues/ch000549.htm)

## Building the project
- Build the project using `cargo build`
- Optionally run the tests using `cargo test`
### Compiling and running
- Build the project using ```cargo build```
- Optionally run the tests using ```cargo test```

## Cross compiling from Linux
#### Cross compiling
The project is pure Rust so one should be able to crosscompile to any platform with a rust target.

### Compiling to Windows from Linux
Make sure you have mingw installed `sudo apt-get install mingw-w64` and the rustc windows target is installed with `rustup target add x86_64-pc-windows-gnu` and build with cargo:
`cargo build --target x86_64-pc-windows-gnu`
**Debian -> windows**
Make sure you have mingw installed ```sudo apt-get install mingw-w64``` and the rustc windows target is installed with ```rustup target add x86_64-pc-windows-gnu``` and build with cargo:
```cargo build --target x86_64-pc-windows-gnu```
2 changes: 1 addition & 1 deletion benches/reachability_bench.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ pub mod bench_helper;
pub mod flamegraph;
use flamegraph::flamegraph_profiler::FlamegraphProfiler;
use reveaal::extract_system_rep::create_executable_query;
use reveaal::ModelObjects::Query;
use reveaal::model_objects::Query;
use reveaal::{parse_queries, ComponentLoader};

fn bench_reachability(c: &mut Criterion, query: &str, loader: &mut Box<dyn ComponentLoader>) {
Expand Down
6 changes: 3 additions & 3 deletions benches/refinement_bench.rs
Original file line number Diff line number Diff line change
Expand Up @@ -5,9 +5,9 @@ pub mod flamegraph;

use flamegraph::flamegraph_profiler::FlamegraphProfiler;
use reveaal::extract_system_rep::create_executable_query;
use reveaal::ModelObjects::Query;
use reveaal::System::executable_query::ExecutableQuery;
use reveaal::System::query_failures::QueryResult;
use reveaal::model_objects::Query;
use reveaal::system::executable_query::ExecutableQuery;
use reveaal::system::query_failures::QueryResult;
use reveaal::{parse_queries, ComponentLoader};

fn construct_query<'a>(
Expand Down
Loading

0 comments on commit 60bbb2a

Please sign in to comment.