From b43bcd43c604126c2b250a30cc56459be754572a Mon Sep 17 00:00:00 2001 From: Aleksey Kladov Date: Tue, 16 Oct 2018 20:53:19 +0300 Subject: fix tests --- crates/tools/src/lib.rs | 35 +++++++++++++++++++---------------- crates/tools/src/main.rs | 19 ++----------------- crates/tools/tests/cli.rs | 15 ++------------- 3 files changed, 23 insertions(+), 46 deletions(-) diff --git a/crates/tools/src/lib.rs b/crates/tools/src/lib.rs index 63ede5315..444745be5 100644 --- a/crates/tools/src/lib.rs +++ b/crates/tools/src/lib.rs @@ -1,13 +1,15 @@ extern crate itertools; -#[macro_use] extern crate failure; +extern crate teraron; -use itertools::Itertools; use std::{ - fs, path::{Path, PathBuf}, }; +use itertools::Itertools; + +pub use teraron::{Mode, Verify, Overwrite}; + pub type Result = ::std::result::Result; pub const GRAMMAR: &str = "ra_syntax/src/grammar.ron"; @@ -54,22 +56,23 @@ pub fn collect_tests(s: &str) -> Vec<(usize, Test)> { res } -pub fn update(path: &Path, contents: &str, verify: bool) -> Result<()> { - match fs::read_to_string(path) { - Ok(ref old_contents) if old_contents == contents => { - return Ok(()); - } - _ => (), - } - if verify { - bail!("`{}` is not up-to-date", path.display()); - } - eprintln!("updating {}", path.display()); - fs::write(path, contents)?; +pub fn generate(mode: Mode) -> Result<()> { + let grammar = project_root().join(GRAMMAR); + let syntax_kinds = project_root().join(SYNTAX_KINDS); + let ast = project_root().join(AST); + teraron::generate( + &syntax_kinds, + &grammar, + mode, + )?; + teraron::generate( + &ast, + &grammar, + mode, + )?; Ok(()) } - pub fn project_root() -> PathBuf { Path::new(&std::env::var("CARGO_MANIFEST_DIR").unwrap()) .parent() diff --git a/crates/tools/src/main.rs b/crates/tools/src/main.rs index 1bbc43123..965bc7729 100644 --- a/crates/tools/src/main.rs +++ b/crates/tools/src/main.rs @@ -13,9 +13,8 @@ use std::{ process::Command, }; use tools::{ - collect_tests, project_root, Result, Test, AST, SYNTAX_KINDS, GRAMMAR, + collect_tests, Result, Test, generate, Mode, Overwrite, Verify, }; -use teraron::{Mode, Verify, Overwrite}; const GRAMMAR_DIR: &str = "./crates/ra_syntax/src/grammar"; const INLINE_TESTS_DIR: &str = "./crates/ra_syntax/tests/data/parser/inline"; @@ -41,21 +40,7 @@ fn main() -> Result<()> { match matches.subcommand() { ("install-code", _) => install_code_extension()?, ("gen-tests", _) => gen_tests(mode)?, - ("gen-kinds", _) => { - let grammar = project_root().join(GRAMMAR); - let syntax_kinds = project_root().join(SYNTAX_KINDS); - let ast = project_root().join(AST); - teraron::generate( - &syntax_kinds, - &grammar, - mode, - )?; - teraron::generate( - &ast, - &grammar, - mode, - )?; - } + ("gen-kinds", _) => generate(Overwrite)?, _ => unreachable!(), } Ok(()) diff --git a/crates/tools/tests/cli.rs b/crates/tools/tests/cli.rs index 16899bb5f..0bb5d15d8 100644 --- a/crates/tools/tests/cli.rs +++ b/crates/tools/tests/cli.rs @@ -1,23 +1,12 @@ extern crate tools; use tools::{ - project_root, render_template, update, AST, AST_TEMPLATE, SYNTAX_KINDS, SYNTAX_KINDS_TEMPLATE, + generate, Verify }; #[test] fn verify_template_generation() { - if let Err(error) = update( - &project_root().join(SYNTAX_KINDS), - &render_template(&project_root().join(SYNTAX_KINDS_TEMPLATE)).unwrap(), - true, - ) { - panic!("{}. Please update it by running `cargo gen-kinds`", error); - } - if let Err(error) = update( - &project_root().join(AST), - &render_template(&project_root().join(AST_TEMPLATE)).unwrap(), - true, - ) { + if let Err(error) = generate(Verify) { panic!("{}. Please update it by running `cargo gen-kinds`", error); } } -- cgit v1.2.3