mirror of
https://github.com/AleoHQ/leo.git
synced 2024-12-12 06:53:10 +03:00
88 lines
2.6 KiB
Rust
88 lines
2.6 KiB
Rust
// Copyright (C) 2019-2020 Aleo Systems Inc.
|
|
// This file is part of the Leo library.
|
|
|
|
// The Leo library is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
|
|
// The Leo library is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
|
|
// You should have received a copy of the GNU General Public License
|
|
// along with the Leo library. If not, see <https://www.gnu.org/licenses/>.
|
|
pub mod variables;
|
|
|
|
use leo_ast::LeoAst;
|
|
use leo_dynamic_check::DynamicCheck;
|
|
|
|
use leo_imports::ImportParser;
|
|
use leo_static_check::{StaticCheck, SymbolTable};
|
|
use leo_typed::{Input, LeoTypedAst, Program};
|
|
use std::path::PathBuf;
|
|
|
|
const TEST_PROGRAM_PATH: &str = "";
|
|
const TEST_PROGRAM_NAME: &str = "test";
|
|
|
|
/// A helper struct to test a `DynamicCheck`.
|
|
pub struct TestDynamicCheck {
|
|
program: Program,
|
|
symbol_table: SymbolTable,
|
|
}
|
|
|
|
impl TestDynamicCheck {
|
|
pub fn new(bytes: &[u8]) -> Self {
|
|
// Get file string from bytes.
|
|
let file_string = String::from_utf8_lossy(bytes);
|
|
|
|
// Get test file path.
|
|
let file_path = PathBuf::from(TEST_PROGRAM_PATH);
|
|
|
|
// Get parser syntax tree.
|
|
let ast = LeoAst::new(&file_path, &*file_string).unwrap();
|
|
|
|
// Get typed syntax tree.
|
|
let typed = LeoTypedAst::new(TEST_PROGRAM_NAME, &ast);
|
|
let program = typed.into_repr();
|
|
|
|
// Create empty import parser.
|
|
let import_parser = ImportParser::new();
|
|
|
|
// Create empty input.
|
|
let input = Input::new();
|
|
|
|
// Create static check.
|
|
let symbol_table = StaticCheck::run_with_input(&program, &import_parser, &input).unwrap();
|
|
|
|
// Store fields for new dynamic check.
|
|
Self { program, symbol_table }
|
|
}
|
|
|
|
pub fn solve(self) {
|
|
let dynamic_check = DynamicCheck::new(&self.program, self.symbol_table).unwrap();
|
|
|
|
dynamic_check.solve().unwrap();
|
|
}
|
|
|
|
pub fn expect_create_error(self) {
|
|
assert!(DynamicCheck::new(&self.program, self.symbol_table).is_err());
|
|
}
|
|
|
|
pub fn expect_solve_error(self) {
|
|
let dynamic_check = DynamicCheck::new(&self.program, self.symbol_table).unwrap();
|
|
|
|
assert!(dynamic_check.solve().is_err());
|
|
}
|
|
}
|
|
|
|
#[test]
|
|
fn test_new() {
|
|
let bytes = include_bytes!("empty.leo");
|
|
|
|
let dynamic_check = TestDynamicCheck::new(bytes);
|
|
|
|
dynamic_check.solve()
|
|
}
|