[INFO] cloning repository https://github.com/sithijaherath/final-project-programing-languages-
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/sithijaherath/final-project-programing-languages-" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fsithijaherath%2Ffinal-project-programing-languages-", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fsithijaherath%2Ffinal-project-programing-languages-'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 630fb2c498c1dfedaec973432697f45a2d6bf140
[INFO] testing sithijaherath/final-project-programing-languages- against try#9f93af291970322f4f1c6315ccde4d7078201159 for pr-146098-6
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fsithijaherath%2Ffinal-project-programing-languages-" "/workspace/builds/worker-6-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-6-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/sithijaherath/final-project-programing-languages-
[INFO] finished tweaking git repo https://github.com/sithijaherath/final-project-programing-languages-
[INFO] tweaked toml for git repo https://github.com/sithijaherath/final-project-programing-languages- written to /workspace/builds/worker-6-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/sithijaherath/final-project-programing-languages- on toolchain 9f93af291970322f4f1c6315ccde4d7078201159
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+9f93af291970322f4f1c6315ccde4d7078201159" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/sithijaherath/final-project-programing-languages- already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+9f93af291970322f4f1c6315ccde4d7078201159" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+9f93af291970322f4f1c6315ccde4d7078201159" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 8872bfaafa1ea2c9121eceda2855049fc4671cc0a7e06ff682bfb41b3faa24d9
[INFO] running `Command { std: "docker" "start" "-a" "8872bfaafa1ea2c9121eceda2855049fc4671cc0a7e06ff682bfb41b3faa24d9", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "8872bfaafa1ea2c9121eceda2855049fc4671cc0a7e06ff682bfb41b3faa24d9", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "8872bfaafa1ea2c9121eceda2855049fc4671cc0a7e06ff682bfb41b3faa24d9", kill_on_drop: false }`
[INFO] [stdout] 8872bfaafa1ea2c9121eceda2855049fc4671cc0a7e06ff682bfb41b3faa24d9
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+9f93af291970322f4f1c6315ccde4d7078201159" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 854e5f10c248a734bdd93b444c863e6e890b4456509b720c7bb5071c95307cfc
[INFO] running `Command { std: "docker" "start" "-a" "854e5f10c248a734bdd93b444c863e6e890b4456509b720c7bb5071c95307cfc", kill_on_drop: false }`
[INFO] [stderr]    Compiling sithija_herath_mudiyanselage_appuhamy v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/parser.rs:18:21
[INFO] [stdout]    |
[INFO] [stdout] 18 |     UnexpectedToken(String),    // When a token doesn't match what's expected
[INFO] [stdout]    |     --------------- ^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ParseError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 18 -     UnexpectedToken(String),    // When a token doesn't match what's expected
[INFO] [stdout] 18 +     UnexpectedToken(()),    // When a token doesn't match what's expected
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `UnterminatedString` and `InvalidTableDefinition` are never constructed
[INFO] [stdout]   --> src/parser.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub enum ParseError {
[INFO] [stdout]    |          ---------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 23 |     UnterminatedString,         // When a string literal isn't closed
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 24 |     InvalidTableDefinition,     // When CREATE TABLE syntax is wrong
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ParseError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `peek`, `expect`, and `is_operator` are never used
[INFO] [stdout]   --> src/parser.rs:47:8
[INFO] [stdout]    |
[INFO] [stdout] 30 | impl<'a> Parser<'a> {
[INFO] [stdout]    | ------------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 47 |     fn peek(&mut self) -> Option<&Token> {
[INFO] [stdout]    |        ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 52 |     fn expect(&mut self, expected: Token) -> Result<(), ParseError> {
[INFO] [stdout]    |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 77 |     fn is_operator(token: &Token) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 0.47s
[INFO] running `Command { std: "docker" "inspect" "854e5f10c248a734bdd93b444c863e6e890b4456509b720c7bb5071c95307cfc", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "854e5f10c248a734bdd93b444c863e6e890b4456509b720c7bb5071c95307cfc", kill_on_drop: false }`
[INFO] [stdout] 854e5f10c248a734bdd93b444c863e6e890b4456509b720c7bb5071c95307cfc
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+9f93af291970322f4f1c6315ccde4d7078201159" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] feb58572979bd2bcf74ddb1a549a4691119110f55b44729c36d05ec7d0267cfa
[INFO] running `Command { std: "docker" "start" "-a" "feb58572979bd2bcf74ddb1a549a4691119110f55b44729c36d05ec7d0267cfa", kill_on_drop: false }`
[INFO] [stderr]    Compiling sithija_herath_mudiyanselage_appuhamy v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/parser.rs:18:21
[INFO] [stdout]    |
[INFO] [stdout] 18 |     UnexpectedToken(String),    // When a token doesn't match what's expected
[INFO] [stdout]    |     --------------- ^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ParseError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 18 -     UnexpectedToken(String),    // When a token doesn't match what's expected
[INFO] [stdout] 18 +     UnexpectedToken(()),    // When a token doesn't match what's expected
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `UnterminatedString` and `InvalidTableDefinition` are never constructed
[INFO] [stdout]   --> src/parser.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub enum ParseError {
[INFO] [stdout]    |          ---------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 23 |     UnterminatedString,         // When a string literal isn't closed
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 24 |     InvalidTableDefinition,     // When CREATE TABLE syntax is wrong
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ParseError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `peek`, `expect`, and `is_operator` are never used
[INFO] [stdout]   --> src/parser.rs:47:8
[INFO] [stdout]    |
[INFO] [stdout] 30 | impl<'a> Parser<'a> {
[INFO] [stdout]    | ------------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 47 |     fn peek(&mut self) -> Option<&Token> {
[INFO] [stdout]    |        ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 52 |     fn expect(&mut self, expected: Token) -> Result<(), ParseError> {
[INFO] [stdout]    |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 77 |     fn is_operator(token: &Token) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.52s
[INFO] running `Command { std: "docker" "inspect" "feb58572979bd2bcf74ddb1a549a4691119110f55b44729c36d05ec7d0267cfa", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "feb58572979bd2bcf74ddb1a549a4691119110f55b44729c36d05ec7d0267cfa", kill_on_drop: false }`
[INFO] [stdout] feb58572979bd2bcf74ddb1a549a4691119110f55b44729c36d05ec7d0267cfa
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+9f93af291970322f4f1c6315ccde4d7078201159" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] bded0799190cabc5312c1e44a7cec3587720b7d8d3a52ce832d7e6d711278b87
[INFO] running `Command { std: "docker" "start" "-a" "bded0799190cabc5312c1e44a7cec3587720b7d8d3a52ce832d7e6d711278b87", kill_on_drop: false }`
[INFO] [stderr] warning: field `0` is never read
[INFO] [stdout] 
[INFO] [stderr]   --> src/parser.rs:18:21
[INFO] [stdout] running 2 tests
[INFO] [stderr]    |
[INFO] [stdout] test parser::tests::test_create_table_with_check_constraints ... ok
[INFO] [stderr] 18 |     UnexpectedToken(String),    // When a token doesn't match what's expected
[INFO] [stderr]    |     --------------- ^^^^^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     field in this variant
[INFO] [stderr]    |
[INFO] [stderr]    = note: `ParseError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]    |
[INFO] [stderr] 18 -     UnexpectedToken(String),    // When a token doesn't match what's expected
[INFO] [stderr] 18 +     UnexpectedToken(()),    // When a token doesn't match what's expected
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: variants `UnterminatedString` and `InvalidTableDefinition` are never constructed
[INFO] [stderr]   --> src/parser.rs:23:5
[INFO] [stderr]    |
[INFO] [stderr] 17 | pub enum ParseError {
[INFO] [stderr]    |          ---------- variants in this enum
[INFO] [stderr] ...
[INFO] [stderr] 23 |     UnterminatedString,         // When a string literal isn't closed
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 24 |     InvalidTableDefinition,     // When CREATE TABLE syntax is wrong
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `ParseError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `peek`, `expect`, and `is_operator` are never used
[INFO] [stderr]   --> src/parser.rs:47:8
[INFO] [stderr]    |
[INFO] [stderr] 30 | impl<'a> Parser<'a> {
[INFO] [stderr]    | ------------------- associated items in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 47 |     fn peek(&mut self) -> Option<&Token> {
[INFO] [stderr]    |        ^^^^
[INFO] [stderr] ...
[INFO] [stderr] 52 |     fn expect(&mut self, expected: Token) -> Result<(), ParseError> {
[INFO] [stderr]    |        ^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 77 |     fn is_operator(token: &Token) -> bool {
[INFO] [stderr]    |        ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `sithija_herath_mudiyanselage_appuhamy` (bin "sithija_herath_mudiyanselage_appuhamy" test) generated 3 warnings
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.03s
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/sithija_herath_mudiyanselage_appuhamy-190326c90326240a)
[INFO] [stdout] test parser::tests::test_complex_check_constraints ... FAILED
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- parser::tests::test_complex_check_constraints stdout ----
[INFO] [stdout] Starting CREATE TABLE parsing
[INFO] [stdout] Parsing table: employee
[INFO] [stdout] Parsing column: id
[INFO] [stdout] Column type parsed: Int
[INFO] [stdout] Parsing constraint, current token: Keyword(Primary)
[INFO] [stdout] Parsing constraint, current token: Comma
[INFO] [stdout] Constraints parsed: [PrimaryKey]
[INFO] [stdout] Column added to list
[INFO] [stdout] Found comma, advancing to next column
[INFO] [stdout] Parsing column: name
[INFO] [stdout] Column type parsed: Varchar(100)
[INFO] [stdout] Parsing constraint, current token: Keyword(Not)
[INFO] [stdout] Parsing constraint, current token: Comma
[INFO] [stdout] Constraints parsed: [NotNull]
[INFO] [stdout] Column added to list
[INFO] [stdout] Found comma, advancing to next column
[INFO] [stdout] Parsing column: salary
[INFO] [stdout] Column type parsed: Int
[INFO] [stdout] Parsing constraint, current token: Keyword(Check)
[INFO] [stdout] Found CHECK constraint
[INFO] [stdout] Parsing expression with precedence 0, current token: Identifier("salary")
[INFO] [stdout] Parsing binary operation with precedence 0, current token: GreaterThanOrEqual
[INFO] [stdout] Parsing expression with precedence 6, current token: Number(30000)
[INFO] [stdout] Parsing binary operation with precedence 6, current token: RightParentheses
[INFO] [stdout] CHECK constraint parsed successfully: BinaryOperation { left_operand: Identifier("salary"), operator: GreaterThanOrEqual, right_operand: Number(30000) }
[INFO] [stdout] Parsing constraint, current token: Comma
[INFO] [stdout] Constraints parsed: [Check(BinaryOperation { left_operand: Identifier("salary"), operator: GreaterThanOrEqual, right_operand: Number(30000) })]
[INFO] [stdout] Column added to list
[INFO] [stdout] Found comma, advancing to next column
[INFO] [stdout] Parsing column: age
[INFO] [stdout] Column type parsed: Int
[INFO] [stdout] Parsing constraint, current token: Keyword(Check)
[INFO] [stdout] Found CHECK constraint
[INFO] [stdout] Parsing expression with precedence 0, current token: LeftParentheses
[INFO] [stdout] Parsing expression with precedence 0, current token: Identifier("age")
[INFO] [stdout] Parsing binary operation with precedence 0, current token: GreaterThanOrEqual
[INFO] [stdout] Parsing expression with precedence 6, current token: Number(18)
[INFO] [stdout] Parsing binary operation with precedence 6, current token: Keyword(And)
[INFO] [stdout] Parsing expression with precedence 5, current token: Identifier("age")
[INFO] [stdout] Parsing binary operation with precedence 5, current token: LessThan
[INFO] [stdout] Parsing expression with precedence 6, current token: Number(65)
[INFO] [stdout] Parsing binary operation with precedence 6, current token: RightParentheses
[INFO] [stdout] Parsing binary operation with precedence 0, current token: Keyword(Or)
[INFO] [stdout] Parsing expression with precedence 4, current token: LeftParentheses
[INFO] [stdout] Parsing expression with precedence 0, current token: Identifier("age")
[INFO] [stdout] Parsing binary operation with precedence 0, current token: GreaterThanOrEqual
[INFO] [stdout] Parsing expression with precedence 6, current token: Number(65)
[INFO] [stdout] Parsing binary operation with precedence 6, current token: Keyword(And)
[INFO] [stdout] Parsing expression with precedence 5, current token: Identifier("salary")
[INFO] [stdout] Parsing binary operation with precedence 5, current token: GreaterThanOrEqual
[INFO] [stdout] Parsing expression with precedence 6, current token: Number(50000)
[INFO] [stdout] Parsing binary operation with precedence 6, current token: RightParentheses
[INFO] [stdout] Parsing binary operation with precedence 4, current token: RightParentheses
[INFO] [stdout] CHECK constraint parsed successfully: BinaryOperation { left_operand: BinaryOperation { left_operand: BinaryOperation { left_operand: Identifier("age"), operator: GreaterThanOrEqual, right_operand: Number(18) }, operator: And, right_operand: BinaryOperation { left_operand: Identifier("age"), operator: LessThan, right_operand: Number(65) } }, operator: Or, right_operand: BinaryOperation { left_operand: BinaryOperation { left_operand: Identifier("age"), operator: GreaterThanOrEqual, right_operand: Number(65) }, operator: And, right_operand: BinaryOperation { left_operand: Identifier("salary"), operator: GreaterThanOrEqual, right_operand: Number(50000) } } }
[INFO] [stdout] Parsing constraint, current token: Comma
[INFO] [stdout] Constraints parsed: [Check(BinaryOperation { left_operand: BinaryOperation { left_operand: BinaryOperation { left_operand: Identifier("age"), operator: GreaterThanOrEqual, right_operand: Number(18) }, operator: And, right_operand: BinaryOperation { left_operand: Identifier("age"), operator: LessThan, right_operand: Number(65) } }, operator: Or, right_operand: BinaryOperation { left_operand: BinaryOperation { left_operand: Identifier("age"), operator: GreaterThanOrEqual, right_operand: Number(65) }, operator: And, right_operand: BinaryOperation { left_operand: Identifier("salary"), operator: GreaterThanOrEqual, right_operand: Number(50000) } } })]
[INFO] [stdout] Column added to list
[INFO] [stdout] Found comma, advancing to next column
[INFO] [stdout] Parsing column: bonus
[INFO] [stdout] Column type parsed: Int
[INFO] [stdout] Parsing constraint, current token: Keyword(Check)
[INFO] [stdout] Found CHECK constraint
[INFO] [stdout] Parsing expression with precedence 0, current token: Identifier("bonus")
[INFO] [stdout] Parsing binary operation with precedence 0, current token: LessThanOrEqual
[INFO] [stdout] Parsing expression with precedence 6, current token: Identifier("salary")
[INFO] [stdout] Parsing binary operation with precedence 6, current token: Star
[INFO] [stdout] Parsing expression with precedence 8, current token: Number(0)
[INFO] [stdout] Parsing binary operation with precedence 8, current token: Invalid('.')
[INFO] [stdout] Expected ) after CHECK expression, got: Invalid('.')
[INFO] [stdout] 
[INFO] [stdout] thread 'parser::tests::test_complex_check_constraints' (25) panicked at src/parser.rs:690:23:
[INFO] [stdout] Failed to parse complex statement: UnmatchedParentheses
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x559f351c9d22 - std::backtrace_rs::backtrace::libunwind::trace::h16affffe904e891e
[INFO] [stdout]                                at /rustc/9f93af291970322f4f1c6315ccde4d7078201159/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x559f351c9d22 - std::backtrace_rs::backtrace::trace_unsynchronized::h5c14b13373ed4150
[INFO] [stdout]                                at /rustc/9f93af291970322f4f1c6315ccde4d7078201159/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x559f351c9d22 - std::sys::backtrace::_print_fmt::hcbb507f162c816cc
[INFO] [stdout]                                at /rustc/9f93af291970322f4f1c6315ccde4d7078201159/library/std/src/sys/backtrace.rs:66:9
[INFO] [stdout]    3:     0x559f351c9d22 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h8be9aa933f14675f
[INFO] [stdout]                                at /rustc/9f93af291970322f4f1c6315ccde4d7078201159/library/std/src/sys/backtrace.rs:39:26
[INFO] [stdout]    4:     0x559f351da38f - core::fmt::rt::Argument::fmt::h30ed739d33467c3a
[INFO] [stdout]                                at /rustc/9f93af291970322f4f1c6315ccde4d7078201159/library/core/src/fmt/rt.rs:173:76
[INFO] [stdout]    5:     0x559f351da38f - core::fmt::write::hfd0efbb002ac7eea
[INFO] [stdout]                                at /rustc/9f93af291970322f4f1c6315ccde4d7078201159/library/core/src/fmt/mod.rs:1469:25
[INFO] [stdout]    6:     0x559f351977f3 - std::io::default_write_fmt::hd6d24501f2d7f8d3
[INFO] [stdout]                                at /rustc/9f93af291970322f4f1c6315ccde4d7078201159/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x559f351977f3 - std::io::Write::write_fmt::h79eca2f72fc24111
[INFO] [stdout]                                at /rustc/9f93af291970322f4f1c6315ccde4d7078201159/library/std/src/io/mod.rs:1954:13
[INFO] [stdout]    8:     0x559f351a3592 - std::sys::backtrace::BacktraceLock::print::hf2554f6030d393f7
[INFO] [stdout]                                at /rustc/9f93af291970322f4f1c6315ccde4d7078201159/library/std/src/sys/backtrace.rs:42:9
[INFO] [stdout]    9:     0x559f351a806f - std::panicking::default_hook::{{closure}}::h8873121c56335b01
[INFO] [stdout]                                at /rustc/9f93af291970322f4f1c6315ccde4d7078201159/library/std/src/panicking.rs:301:27
[INFO] [stdout]   10:     0x559f351a7f01 - std::panicking::default_hook::hbafefc2d196267a2
[INFO] [stdout]                                at /rustc/9f93af291970322f4f1c6315ccde4d7078201159/library/std/src/panicking.rs:325:9
[INFO] [stdout]   11:     0x559f3516b0ce - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::ha834d5846f91b30b
[INFO] [stdout]                                at /rustc/9f93af291970322f4f1c6315ccde4d7078201159/library/alloc/src/boxed.rs:2099:9
[INFO] [stdout]   12:     0x559f3516b0ce - test::test_main_with_exit_callback::{{closure}}::h63c167737eecb025
[INFO] [stdout]                                at /rustc/9f93af291970322f4f1c6315ccde4d7078201159/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x559f351a867f - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hbf9b0f7a281291fd
[INFO] [stdout]                                at /rustc/9f93af291970322f4f1c6315ccde4d7078201159/library/alloc/src/boxed.rs:2099:9
[INFO] [stdout]   14:     0x559f351a867f - std::panicking::panic_with_hook::h9f5b09d5adc1a745
[INFO] [stdout]                                at /rustc/9f93af291970322f4f1c6315ccde4d7078201159/library/std/src/panicking.rs:842:13
[INFO] [stdout]   15:     0x559f351a84da - std::panicking::panic_handler::{{closure}}::h08111e483bdf6a89
[INFO] [stdout]                                at /rustc/9f93af291970322f4f1c6315ccde4d7078201159/library/std/src/panicking.rs:707:13
[INFO] [stdout]   16:     0x559f351a36c9 - std::sys::backtrace::__rust_end_short_backtrace::h1b86e3414ecbbe8d
[INFO] [stdout]                                at /rustc/9f93af291970322f4f1c6315ccde4d7078201159/library/std/src/sys/backtrace.rs:174:18
[INFO] [stdout]   17:     0x559f3518bfbd - __rustc[b292c645e8102103]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/9f93af291970322f4f1c6315ccde4d7078201159/library/std/src/panicking.rs:698:5
[INFO] [stdout]   18:     0x559f351e2110 - core::panicking::panic_fmt::h31cc490ecc8cc1fa
[INFO] [stdout]                                at /rustc/9f93af291970322f4f1c6315ccde4d7078201159/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x559f3513de8a - sithija_herath_mudiyanselage_appuhamy::parser::tests::test_complex_check_constraints::hcdca1af625b39e2a
[INFO] [stdout]                                at /opt/rustwide/workdir/src/parser.rs:690:23
[INFO] [stdout]   20:     0x559f3513deb7 - sithija_herath_mudiyanselage_appuhamy::parser::tests::test_complex_check_constraints::{{closure}}::hd8f0e0eb9f4b09aa
[INFO] [stdout]                                at /opt/rustwide/workdir/src/parser.rs:655:40
[INFO] [stdout]   21:     0x559f35140066 - core::ops::function::FnOnce::call_once::hfc668782ca53708d
[INFO] [stdout]                                at /rustc/9f93af291970322f4f1c6315ccde4d7078201159/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   22:     0x559f3516aecb - core::ops::function::FnOnce::call_once::h2b2de5fdd23aab3e
[INFO] [stdout]                                at /rustc/9f93af291970322f4f1c6315ccde4d7078201159/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   23:     0x559f3516aecb - test::__rust_begin_short_backtrace::he551dd004770be01
[INFO] [stdout]                                at /rustc/9f93af291970322f4f1c6315ccde4d7078201159/library/test/src/lib.rs:663:18
[INFO] [stdout]   24:     0x559f3517ef2d - test::run_test_in_process::{{closure}}::h5f0b44080a35ed87
[INFO] [stdout]                                at /rustc/9f93af291970322f4f1c6315ccde4d7078201159/library/test/src/lib.rs:686:74
[INFO] [stdout]   25:     0x559f3517ef2d - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h4dbf65d14893ecf5
[INFO] [stdout]                                at /rustc/9f93af291970322f4f1c6315ccde4d7078201159/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   26:     0x559f3517ef2d - std::panicking::catch_unwind::do_call::hc37c563b8a006285
[INFO] [stdout]                                at /rustc/9f93af291970322f4f1c6315ccde4d7078201159/library/std/src/panicking.rs:590:40
[INFO] [stdout]   27:     0x559f3517ef2d - std::panicking::catch_unwind::h616b6e2e7a27f612
[INFO] [stdout]                                at /rustc/9f93af291970322f4f1c6315ccde4d7078201159/library/std/src/panicking.rs:553:19
[INFO] [stdout]   28:     0x559f3517ef2d - std::panic::catch_unwind::h1e788dd57758e6d8
[INFO] [stdout]                                at /rustc/9f93af291970322f4f1c6315ccde4d7078201159/library/std/src/panic.rs:359:14
[INFO] [stdout]   29:     0x559f3517ef2d - test::run_test_in_process::hf073c2764f29f8ad
[INFO] [stdout]                                at /rustc/9f93af291970322f4f1c6315ccde4d7078201159/library/test/src/lib.rs:686:27
[INFO] [stdout]   30:     0x559f3517ef2d - test::run_test::{{closure}}::h3dc46b7a0c340fa6
[INFO] [stdout]                                at /rustc/9f93af291970322f4f1c6315ccde4d7078201159/library/test/src/lib.rs:607:43
[INFO] [stdout]   31:     0x559f35158474 - test::run_test::{{closure}}::h6a4da3c57ef4505f
[INFO] [stdout]                                at /rustc/9f93af291970322f4f1c6315ccde4d7078201159/library/test/src/lib.rs:637:41
[INFO] [stdout]   32:     0x559f35158474 - std::sys::backtrace::__rust_begin_short_backtrace::hfd8e44bc311a5d57
[INFO] [stdout]                                at /rustc/9f93af291970322f4f1c6315ccde4d7078201159/library/std/src/sys/backtrace.rs:158:18
[INFO] [stdout]   33:     0x559f3515bcca - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h57c4ddec344fe24c
[INFO] [stdout]                                at /rustc/9f93af291970322f4f1c6315ccde4d7078201159/library/std/src/thread/mod.rs:562:17
[INFO] [stdout]   34:     0x559f3515bcca - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hd7cbe09591f06dfb
[INFO] [stdout]                                at /rustc/9f93af291970322f4f1c6315ccde4d7078201159/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   35:     0x559f3515bcca - std::panicking::catch_unwind::do_call::hdcd076e8e993dfbc
[INFO] [stdout]                                at /rustc/9f93af291970322f4f1c6315ccde4d7078201159/library/std/src/panicking.rs:590:40
[INFO] [stdout]   36:     0x559f3515bcca - std::panicking::catch_unwind::h8f9f675f3756eab1
[INFO] [stdout]                                at /rustc/9f93af291970322f4f1c6315ccde4d7078201159/library/std/src/panicking.rs:553:19
[INFO] [stdout]   37:     0x559f3515bcca - std::panic::catch_unwind::he8f74a93abeceb9b
[INFO] [stdout]                                at /rustc/9f93af291970322f4f1c6315ccde4d7078201159/library/std/src/panic.rs:359:14
[INFO] [stdout]   38:     0x559f3515bcca - std::thread::Builder::spawn_unchecked_::{{closure}}::he43db13a2caa41d5
[INFO] [stdout]                                at /rustc/9f93af291970322f4f1c6315ccde4d7078201159/library/std/src/thread/mod.rs:560:30
[INFO] [stdout]   39:     0x559f3515bcca - core::ops::function::FnOnce::call_once{{vtable.shim}}::h8f3531a7e0d83514
[INFO] [stdout]                                at /rustc/9f93af291970322f4f1c6315ccde4d7078201159/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   40:     0x559f3519eacf - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h6ff05134d80ef20e
[INFO] [stdout]                                at /rustc/9f93af291970322f4f1c6315ccde4d7078201159/library/alloc/src/boxed.rs:2085:9
[INFO] [stdout]   41:     0x559f3519eacf - std::sys::thread::unix::Thread::new::thread_start::h9a4a41a076a486e0
[INFO] [stdout]                                at /rustc/9f93af291970322f4f1c6315ccde4d7078201159/library/std/src/sys/thread/unix.rs:124:17
[INFO] [stdout]   42:     0x7fae3bf28aa4 - <unknown>
[INFO] [stdout]   43:     0x7fae3bfb5a64 - clone
[INFO] [stdout]   44:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     parser::tests::test_complex_check_constraints
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 1 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.03s
[INFO] [stdout] 
[INFO] [stderr] error: test failed, to rerun pass `--bin sithija_herath_mudiyanselage_appuhamy`
[INFO] running `Command { std: "docker" "inspect" "bded0799190cabc5312c1e44a7cec3587720b7d8d3a52ce832d7e6d711278b87", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "bded0799190cabc5312c1e44a7cec3587720b7d8d3a52ce832d7e6d711278b87", kill_on_drop: false }`
[INFO] [stdout] bded0799190cabc5312c1e44a7cec3587720b7d8d3a52ce832d7e6d711278b87
