Add ui tests
This commit is contained in:
parent
c036b7c7c5
commit
73b447a762
|
@ -3,5 +3,6 @@ members = [
|
||||||
"typed-html",
|
"typed-html",
|
||||||
"macros",
|
"macros",
|
||||||
"examples/wasm",
|
"examples/wasm",
|
||||||
"examples/rocket"
|
"examples/rocket",
|
||||||
|
"ui",
|
||||||
]
|
]
|
||||||
|
|
|
@ -0,0 +1,14 @@
|
||||||
|
[package]
|
||||||
|
name = "typed-html-tests"
|
||||||
|
version = "0.0.0"
|
||||||
|
authors = ["Bodil Stokke <bodil@bodil.org>"]
|
||||||
|
publish = false
|
||||||
|
|
||||||
|
[[bin]]
|
||||||
|
name = "typed-html-tests"
|
||||||
|
path = "main.rs"
|
||||||
|
|
||||||
|
[dev-dependencies]
|
||||||
|
compiletest_rs = { version = "0.3", features = ["stable"] }
|
||||||
|
typed-html = { path = "../typed-html" }
|
||||||
|
typed-html-macros = { path = "../macros" }
|
|
@ -0,0 +1,12 @@
|
||||||
|
#![feature(proc_macro_hygiene)]
|
||||||
|
|
||||||
|
extern crate typed_html;
|
||||||
|
|
||||||
|
use typed_html::html;
|
||||||
|
use typed_html::dom::DOMTree;
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
let _: DOMTree<String> = html!{
|
||||||
|
<@>
|
||||||
|
};
|
||||||
|
}
|
|
@ -0,0 +1,8 @@
|
||||||
|
error: expected identifier
|
||||||
|
--> $DIR/expected-token.rs:10:10
|
||||||
|
|
|
||||||
|
10 | <@>
|
||||||
|
| ^
|
||||||
|
|
||||||
|
error: aborting due to previous error
|
||||||
|
|
|
@ -0,0 +1,14 @@
|
||||||
|
#![feature(proc_macro_hygiene)]
|
||||||
|
|
||||||
|
extern crate typed_html;
|
||||||
|
|
||||||
|
use typed_html::html;
|
||||||
|
use typed_html::dom::DOMTree;
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
let _: DOMTree<String> = html!{
|
||||||
|
<html>
|
||||||
|
<head></head>
|
||||||
|
</html>
|
||||||
|
};
|
||||||
|
}
|
|
@ -0,0 +1,21 @@
|
||||||
|
error: <html> requires 2 children but there are only 1
|
||||||
|
--> $DIR/not-enough-children.rs:10:10
|
||||||
|
|
|
||||||
|
10 | <html>
|
||||||
|
| ^^^^
|
||||||
|
|
||||||
|
error: proc macro panicked
|
||||||
|
--> $DIR/not-enough-children.rs:9:30
|
||||||
|
|
|
||||||
|
9 | let _: DOMTree<String> = html!{
|
||||||
|
| ______________________________^
|
||||||
|
10 | | <html>
|
||||||
|
11 | | <head></head>
|
||||||
|
12 | | </html>
|
||||||
|
13 | | };
|
||||||
|
| |_____^
|
||||||
|
|
|
||||||
|
= help: message: explicit panic
|
||||||
|
|
||||||
|
error: aborting due to 2 previous errors
|
||||||
|
|
|
@ -0,0 +1,12 @@
|
||||||
|
#![feature(proc_macro_hygiene)]
|
||||||
|
|
||||||
|
extern crate typed_html;
|
||||||
|
|
||||||
|
use typed_html::html;
|
||||||
|
use typed_html::dom::DOMTree;
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
let _: DOMTree<String> = html!{
|
||||||
|
<html></head>
|
||||||
|
};
|
||||||
|
}
|
|
@ -0,0 +1,14 @@
|
||||||
|
error: expected closing tag '</html>', found '</head>'
|
||||||
|
--> $DIR/tag-mismatch.rs:10:17
|
||||||
|
|
|
||||||
|
10 | <html></head>
|
||||||
|
| ^^^^
|
||||||
|
|
|
||||||
|
help: opening tag is here:
|
||||||
|
--> $DIR/tag-mismatch.rs:10:10
|
||||||
|
|
|
||||||
|
10 | <html></head>
|
||||||
|
| ^^^^
|
||||||
|
|
||||||
|
error: aborting due to previous error
|
||||||
|
|
|
@ -0,0 +1,12 @@
|
||||||
|
#![feature(proc_macro_hygiene)]
|
||||||
|
|
||||||
|
extern crate typed_html;
|
||||||
|
|
||||||
|
use typed_html::html;
|
||||||
|
use typed_html::dom::DOMTree;
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
let _: DOMTree<String> = html!{
|
||||||
|
<title>unquoted</title>
|
||||||
|
};
|
||||||
|
}
|
|
@ -0,0 +1,10 @@
|
||||||
|
error: expected "<", code block or literal
|
||||||
|
--> $DIR/text-nodes-need-to-be-quoted.rs:10:16
|
||||||
|
|
|
||||||
|
10 | <title>unquoted</title>
|
||||||
|
| ^^^^^^^^
|
||||||
|
|
|
||||||
|
= help: text nodes need to be quoted, eg. [1m<p>"Hello Joe!"</p>[0m
|
||||||
|
|
||||||
|
error: aborting due to previous error
|
||||||
|
|
|
@ -0,0 +1,12 @@
|
||||||
|
#![feature(proc_macro_hygiene)]
|
||||||
|
|
||||||
|
extern crate typed_html;
|
||||||
|
|
||||||
|
use typed_html::html;
|
||||||
|
use typed_html::dom::DOMTree;
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
let _: DOMTree<String> = html!{
|
||||||
|
<title>
|
||||||
|
};
|
||||||
|
}
|
|
@ -0,0 +1,10 @@
|
||||||
|
error: unexpected end of macro
|
||||||
|
--> $DIR/unexpected-end-of-macro.rs:10:9
|
||||||
|
|
|
||||||
|
10 | <title>
|
||||||
|
| ^^^^^^^
|
||||||
|
|
|
||||||
|
= help: missing "<", code block or literal
|
||||||
|
|
||||||
|
error: aborting due to previous error
|
||||||
|
|
|
@ -0,0 +1,48 @@
|
||||||
|
#!/bin/bash
|
||||||
|
#
|
||||||
|
# Copyright 2015 The Rust Project Developers. See the COPYRIGHT
|
||||||
|
# file at the top-level directory of this distribution and at
|
||||||
|
# http://rust-lang.org/COPYRIGHT.
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
||||||
|
# <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
||||||
|
# option. This file may not be copied, modified, or distributed
|
||||||
|
# except according to those terms.
|
||||||
|
|
||||||
|
# A script to update the references for particular tests. The idea is
|
||||||
|
# that you do a run, which will generate files in the build directory
|
||||||
|
# containing the (normalized) actual output of the compiler. This
|
||||||
|
# script will then copy that output and replace the "expected output"
|
||||||
|
# files. You can then commit the changes.
|
||||||
|
#
|
||||||
|
# If you find yourself manually editing a foo.stderr file, you're
|
||||||
|
# doing it wrong.
|
||||||
|
|
||||||
|
if [[ "$1" == "--help" || "$1" == "-h" || "$1" == "" || "$2" == "" ]]; then
|
||||||
|
echo "usage: $0 <build-directory> <relative-path-to-rs-files>"
|
||||||
|
echo ""
|
||||||
|
echo "For example:"
|
||||||
|
echo " $0 ../../../build/x86_64-apple-darwin/test/ui *.rs */*.rs"
|
||||||
|
fi
|
||||||
|
|
||||||
|
MYDIR=$(dirname $0)
|
||||||
|
|
||||||
|
BUILD_DIR="$1"
|
||||||
|
shift
|
||||||
|
|
||||||
|
while [[ "$1" != "" ]]; do
|
||||||
|
STDERR_NAME="${1/%.rs/.stderr}"
|
||||||
|
STDOUT_NAME="${1/%.rs/.stdout}"
|
||||||
|
shift
|
||||||
|
if [ -f $BUILD_DIR/$STDOUT_NAME ] && \
|
||||||
|
! (diff $BUILD_DIR/$STDOUT_NAME $MYDIR/$STDOUT_NAME >& /dev/null); then
|
||||||
|
echo updating $MYDIR/$STDOUT_NAME
|
||||||
|
cp $BUILD_DIR/$STDOUT_NAME $MYDIR/$STDOUT_NAME
|
||||||
|
fi
|
||||||
|
if [ -f $BUILD_DIR/$STDERR_NAME ] && \
|
||||||
|
! (diff $BUILD_DIR/$STDERR_NAME $MYDIR/$STDERR_NAME >& /dev/null); then
|
||||||
|
echo updating $MYDIR/$STDERR_NAME
|
||||||
|
cp $BUILD_DIR/$STDERR_NAME $MYDIR/$STDERR_NAME
|
||||||
|
fi
|
||||||
|
done
|
|
@ -0,0 +1,15 @@
|
||||||
|
#[test]
|
||||||
|
fn ui() {
|
||||||
|
extern crate compiletest_rs as compiletest;
|
||||||
|
|
||||||
|
let mut config = compiletest::Config {
|
||||||
|
mode: compiletest::common::Mode::Ui,
|
||||||
|
src_base: std::path::PathBuf::from("cases"),
|
||||||
|
..Default::default()
|
||||||
|
};
|
||||||
|
|
||||||
|
config.link_deps();
|
||||||
|
config.clean_rmeta();
|
||||||
|
|
||||||
|
compiletest::run_tests(&config);
|
||||||
|
}
|
Loading…
Reference in New Issue