[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 master#1ef7943ee607160a564655b6596f83670ef95df5 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-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-6-tc1/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-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/sithijaherath/final-project-programing-languages- on toolchain 1ef7943ee607160a564655b6596f83670ef95df5
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1ef7943ee607160a564655b6596f83670ef95df5" "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" "+1ef7943ee607160a564655b6596f83670ef95df5" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/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" "+1ef7943ee607160a564655b6596f83670ef95df5" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 1580f3aead1749483597080a69ec68dbe51043247277dc7a5370ed0aa40e0061
[INFO] running `Command { std: "docker" "start" "-a" "1580f3aead1749483597080a69ec68dbe51043247277dc7a5370ed0aa40e0061", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "1580f3aead1749483597080a69ec68dbe51043247277dc7a5370ed0aa40e0061", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "1580f3aead1749483597080a69ec68dbe51043247277dc7a5370ed0aa40e0061", kill_on_drop: false }`
[INFO] [stdout] 1580f3aead1749483597080a69ec68dbe51043247277dc7a5370ed0aa40e0061
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/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" "+1ef7943ee607160a564655b6596f83670ef95df5" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 6de142a89612c79e12f9ef51846b91cf5b7420c3250ca7da2e475105583006d2
[INFO] running `Command { std: "docker" "start" "-a" "6de142a89612c79e12f9ef51846b91cf5b7420c3250ca7da2e475105583006d2", 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.72s
[INFO] running `Command { std: "docker" "inspect" "6de142a89612c79e12f9ef51846b91cf5b7420c3250ca7da2e475105583006d2", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "6de142a89612c79e12f9ef51846b91cf5b7420c3250ca7da2e475105583006d2", kill_on_drop: false }`
[INFO] [stdout] 6de142a89612c79e12f9ef51846b91cf5b7420c3250ca7da2e475105583006d2
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/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" "+1ef7943ee607160a564655b6596f83670ef95df5" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 6e315115507c4dfd4ad2e78acd2a7603ce6a675797bd31d2f30c31580959a710
[INFO] running `Command { std: "docker" "start" "-a" "6e315115507c4dfd4ad2e78acd2a7603ce6a675797bd31d2f30c31580959a710", 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.65s
[INFO] running `Command { std: "docker" "inspect" "6e315115507c4dfd4ad2e78acd2a7603ce6a675797bd31d2f30c31580959a710", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "6e315115507c4dfd4ad2e78acd2a7603ce6a675797bd31d2f30c31580959a710", kill_on_drop: false }`
[INFO] [stdout] 6e315115507c4dfd4ad2e78acd2a7603ce6a675797bd31d2f30c31580959a710
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/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" "+1ef7943ee607160a564655b6596f83670ef95df5" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 2e7c23d203d6ed4a0ca277efdadeaa29221c4a238d23fd75c9ac8ef32a5b2681
[INFO] running `Command { std: "docker" "start" "-a" "2e7c23d203d6ed4a0ca277efdadeaa29221c4a238d23fd75c9ac8ef32a5b2681", kill_on_drop: false }`
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]   --> src/parser.rs:18:21
[INFO] [stderr]    |
[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.06s
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/sithija_herath_mudiyanselage_appuhamy-190326c90326240a)
[INFO] [stdout] 
[INFO] [stdout] running 2 tests
[INFO] [stdout] test parser::tests::test_create_table_with_check_constraints ... ok
[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:     0x5e07edbe2d22 - std::backtrace_rs::backtrace::libunwind::trace::h786de35fecf3582f
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x5e07edbe2d22 - std::backtrace_rs::backtrace::trace_unsynchronized::h4a7da1a2a64387f1
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x5e07edbe2d22 - std::sys::backtrace::_print_fmt::h6bd7d500070c788c
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/sys/backtrace.rs:66:9
[INFO] [stdout]    3:     0x5e07edbe2d22 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h6d82c1afff976903
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/sys/backtrace.rs:39:26
[INFO] [stdout]    4:     0x5e07edbf338f - core::fmt::rt::Argument::fmt::hc4ce6d643d397690
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/fmt/rt.rs:173:76
[INFO] [stdout]    5:     0x5e07edbf338f - core::fmt::write::hb1e7ca88b6a3936e
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/fmt/mod.rs:1469:25
[INFO] [stdout]    6:     0x5e07edbb06c3 - std::io::default_write_fmt::haffd49d96f1984a8
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x5e07edbb06c3 - std::io::Write::write_fmt::h027871c57cf57c01
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/io/mod.rs:1954:13
[INFO] [stdout]    8:     0x5e07edbbc592 - std::sys::backtrace::BacktraceLock::print::ha2430613ee79d059
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/sys/backtrace.rs:42:9
[INFO] [stdout]    9:     0x5e07edbc106f - std::panicking::default_hook::{{closure}}::hdbd2db9e5c303cf6
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:301:27
[INFO] [stdout]   10:     0x5e07edbc0f01 - std::panicking::default_hook::hed93c70cba5fdcf0
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:325:9
[INFO] [stdout]   11:     0x5e07edb840ce - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hd0ee8b569efc6a07
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/alloc/src/boxed.rs:2099:9
[INFO] [stdout]   12:     0x5e07edb840ce - test::test_main_with_exit_callback::{{closure}}::hf10864b576ecd15d
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x5e07edbc167f - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h3a55ca34534c0d00
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/alloc/src/boxed.rs:2099:9
[INFO] [stdout]   14:     0x5e07edbc167f - std::panicking::panic_with_hook::h3862d766c2cec19b
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:842:13
[INFO] [stdout]   15:     0x5e07edbc14da - std::panicking::panic_handler::{{closure}}::hb95eb402b5e28ee1
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:707:13
[INFO] [stdout]   16:     0x5e07edbbc6c9 - std::sys::backtrace::__rust_end_short_backtrace::hf73a26dc1835d85a
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/sys/backtrace.rs:174:18
[INFO] [stdout]   17:     0x5e07edba4fbd - __rustc[6ed5915ee467787]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:698:5
[INFO] [stdout]   18:     0x5e07edbfb110 - core::panicking::panic_fmt::h3454303eb8e6f7cd
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x5e07edb56e8a - sithija_herath_mudiyanselage_appuhamy::parser::tests::test_complex_check_constraints::h9f4e4a3a78817839
[INFO] [stdout]                                at /opt/rustwide/workdir/src/parser.rs:690:23
[INFO] [stdout]   20:     0x5e07edb56eb7 - sithija_herath_mudiyanselage_appuhamy::parser::tests::test_complex_check_constraints::{{closure}}::hb37a920dacbb5639
[INFO] [stdout]                                at /opt/rustwide/workdir/src/parser.rs:655:40
[INFO] [stdout]   21:     0x5e07edb59066 - core::ops::function::FnOnce::call_once::hcc998af5c448c70e
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   22:     0x5e07edb83eab - core::ops::function::FnOnce::call_once::ha729ee35d2fab541
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   23:     0x5e07edb83eab - test::__rust_begin_short_backtrace::ha40f4db8207e1111
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/test/src/lib.rs:663:18
[INFO] [stdout]   24:     0x5e07edb97f2d - test::run_test_in_process::{{closure}}::hc1b77cda5d44f0f3
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/test/src/lib.rs:686:74
[INFO] [stdout]   25:     0x5e07edb97f2d - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h1dbea1de64785521
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   26:     0x5e07edb97f2d - std::panicking::catch_unwind::do_call::hd5febe9affd5a1b3
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:590:40
[INFO] [stdout]   27:     0x5e07edb97f2d - std::panicking::catch_unwind::h51ea89627559b6f4
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:553:19
[INFO] [stdout]   28:     0x5e07edb97f2d - std::panic::catch_unwind::hb8b8c2367cae3d66
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panic.rs:359:14
[INFO] [stdout]   29:     0x5e07edb97f2d - test::run_test_in_process::ha5b55801407ea100
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/test/src/lib.rs:686:27
[INFO] [stdout]   30:     0x5e07edb97f2d - test::run_test::{{closure}}::h0b9d4072b527abf5
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/test/src/lib.rs:607:43
[INFO] [stdout]   31:     0x5e07edb71444 - test::run_test::{{closure}}::hb1056b5731205822
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/test/src/lib.rs:637:41
[INFO] [stdout]   32:     0x5e07edb71444 - std::sys::backtrace::__rust_begin_short_backtrace::hb61ff5a34023c7ef
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/sys/backtrace.rs:158:18
[INFO] [stdout]   33:     0x5e07edb74d7a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::hb0a83c0e8b353cff
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/thread/mod.rs:562:17
[INFO] [stdout]   34:     0x5e07edb74d7a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hb4f32cb008535298
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   35:     0x5e07edb74d7a - std::panicking::catch_unwind::do_call::h16d110e4fc35789a
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:590:40
[INFO] [stdout]   36:     0x5e07edb74d7a - std::panicking::catch_unwind::hea9118f355699c4b
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:553:19
[INFO] [stdout]   37:     0x5e07edb74d7a - std::panic::catch_unwind::hf4b3c2a06d3f42f5
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panic.rs:359:14
[INFO] [stdout]   38:     0x5e07edb74d7a - std::thread::Builder::spawn_unchecked_::{{closure}}::h3f4cb733a52d53d5
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/thread/mod.rs:560:30
[INFO] [stdout]   39:     0x5e07edb74d7a - core::ops::function::FnOnce::call_once{{vtable.shim}}::h4052f0967b37caeb
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   40:     0x5e07edbb7acf - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h7ec433abd3f148b4
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/alloc/src/boxed.rs:2085:9
[INFO] [stdout]   41:     0x5e07edbb7acf - std::sys::thread::unix::Thread::new::thread_start::he514622d3d7ba65c
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/sys/thread/unix.rs:124:17
[INFO] [stdout]   42:     0x70858fedcaa4 - <unknown>
[INFO] [stdout]   43:     0x70858ff69a64 - clone
[INFO] [stdout]   44:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr] error: test failed, to rerun pass `--bin sithija_herath_mudiyanselage_appuhamy`
[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.02s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "2e7c23d203d6ed4a0ca277efdadeaa29221c4a238d23fd75c9ac8ef32a5b2681", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "2e7c23d203d6ed4a0ca277efdadeaa29221c4a238d23fd75c9ac8ef32a5b2681", kill_on_drop: false }`
[INFO] [stdout] 2e7c23d203d6ed4a0ca277efdadeaa29221c4a238d23fd75c9ac8ef32a5b2681
