From 3d1cfd43bec7c22928d12ab235151b8eeeaf4e96 Mon Sep 17 00:00:00 2001 From: Tom Tromey Date: Wed, 1 Apr 2020 14:02:08 -0600 Subject: [PATCH] Move Rust union tests to new file I wanted to run the gdb.rust tests against older versions of the Rust compiler, to ensure that changes I am making don't break debugging when using older compilers. However, this did not work because simple.rs now uses unchecked unions, which were only added in Rust 1.19. This patch splits the union code into its own file, so that simple.exp can continue to work. I tested this with selected rust versions back to 1.12. gdb/testsuite/ChangeLog 2020-04-01 Tom Tromey * gdb.rust/union.rs: New file. * gdb.rust/union.exp: New file. * gdb.rust/simple.rs (Union, Union2): Move to union.rs. (main): Update. * gdb.rust/simple.exp: Move union tests to union.exp. --- gdb/testsuite/ChangeLog | 8 ++++++ gdb/testsuite/gdb.rust/simple.exp | 13 --------- gdb/testsuite/gdb.rust/simple.rs | 12 --------- gdb/testsuite/gdb.rust/union.exp | 45 +++++++++++++++++++++++++++++++ gdb/testsuite/gdb.rust/union.rs | 35 ++++++++++++++++++++++++ 5 files changed, 88 insertions(+), 25 deletions(-) create mode 100644 gdb/testsuite/gdb.rust/union.exp create mode 100644 gdb/testsuite/gdb.rust/union.rs diff --git a/gdb/testsuite/ChangeLog b/gdb/testsuite/ChangeLog index 7819e39b972..cc17eba7700 100644 --- a/gdb/testsuite/ChangeLog +++ b/gdb/testsuite/ChangeLog @@ -1,3 +1,11 @@ +2020-04-01 Tom Tromey + + * gdb.rust/union.rs: New file. + * gdb.rust/union.exp: New file. + * gdb.rust/simple.rs (Union, Union2): Move to union.rs. + (main): Update. + * gdb.rust/simple.exp: Move union tests to union.exp. + 2020-04-01 Tom Tromey * gdb.rust/simple.rs (main): Remove "y0". diff --git a/gdb/testsuite/gdb.rust/simple.exp b/gdb/testsuite/gdb.rust/simple.exp index b4fcf274261..92b3666386b 100644 --- a/gdb/testsuite/gdb.rust/simple.exp +++ b/gdb/testsuite/gdb.rust/simple.exp @@ -335,17 +335,6 @@ gdb_test "print parametrized.next.val" \ gdb_test "print parametrized" \ " = simple::ParametrizedStruct \\{next: simple::ParametrizedEnum<\[a-z:\]*Box>>::Val\\{val: $hex\\}, value: 0\\}" -gdb_test "print u" " = simple::Union {f1: -1, f2: 255}" - -gdb_test_sequence "ptype/o Union" "" { - "/\\* offset | size \\*/ type = union simple::Union {" - "/\\* 1 \\*/ f1: i8," - "/\\* 1 \\*/ f2: u8," - "" - " /\\* total size \\(bytes\\): 1 \\*/" - " }" -} - gdb_test_sequence "ptype/o SimpleLayout" "" { "/\\* offset | size \\*/ type = struct simple::SimpleLayout {" "/\\* 0 | 2 \\*/ f1: u16," @@ -355,8 +344,6 @@ gdb_test_sequence "ptype/o SimpleLayout" "" { " }" } -gdb_test "print u2" " = simple::Union2 {name: \\\[1\\\]}" - gdb_test "print nonzero_offset" " = simple::EnumWithNonzeroOffset {a: core::option::Option::Some\\(1\\), b: core::option::Option::None}" # PR rust/23626 - this used to crash. Note that the results are diff --git a/gdb/testsuite/gdb.rust/simple.rs b/gdb/testsuite/gdb.rust/simple.rs index f44e4affebd..78c3b217451 100644 --- a/gdb/testsuite/gdb.rust/simple.rs +++ b/gdb/testsuite/gdb.rust/simple.rs @@ -80,15 +80,6 @@ struct ParametrizedStruct { value: T } -union Union { - f1: i8, - f2: u8, -} - -pub union Union2 { - pub name: [u8; 1], -} - struct StringAtOffset { pub field1: &'static str, pub field2: i32, @@ -184,13 +175,10 @@ fn main () { value: 0, }; - let u = Union { f2: 255 }; let simplelayout = SimpleLayout { f1: 8, f2: 9 }; let empty_enum_value: EmptyEnum; - let u2 = Union2 { name: [1] }; - let nonzero_offset = EnumWithNonzeroOffset { a: Some(1), b: None }; println!("{}, {}", x.0, x.1); // set breakpoint here diff --git a/gdb/testsuite/gdb.rust/union.exp b/gdb/testsuite/gdb.rust/union.exp new file mode 100644 index 00000000000..c7864a2fc9d --- /dev/null +++ b/gdb/testsuite/gdb.rust/union.exp @@ -0,0 +1,45 @@ +# Copyright (C) 2020 Free Software Foundation, Inc. + +# This program 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. +# +# This program 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 this program. If not, see . + +# Test of "union" for Rust. + +load_lib rust-support.exp +if {[skip_rust_tests]} { + continue +} + +standard_testfile .rs +if {[prepare_for_testing "failed to prepare" $testfile $srcfile {debug rust}]} { + return -1 +} + +set line [gdb_get_line_number "set breakpoint here"] +if {![runto ${srcfile}:$line]} { + untested "could not run to breakpoint" + return -1 +} + +gdb_test "print u" " = union::Union {f1: -1, f2: 255}" + +gdb_test_sequence "ptype/o Union" "" { + "/\\* offset | size \\*/ type = union union::Union {" + "/\\* 1 \\*/ f1: i8," + "/\\* 1 \\*/ f2: u8," + "" + " /\\* total size \\(bytes\\): 1 \\*/" + " }" +} + +gdb_test "print u2" " = union::Union2 {name: \\\[1\\\]}" diff --git a/gdb/testsuite/gdb.rust/union.rs b/gdb/testsuite/gdb.rust/union.rs new file mode 100644 index 00000000000..ef3069641bc --- /dev/null +++ b/gdb/testsuite/gdb.rust/union.rs @@ -0,0 +1,35 @@ +// Copyright (C) 2020 Free Software Foundation, Inc. + +// This program 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. +// +// This program 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 this program. If not, see . + +#![allow(dead_code)] +#![allow(unused_variables)] +#![allow(unused_assignments)] + + +union Union { + f1: i8, + f2: u8, +} + +pub union Union2 { + pub name: [u8; 1], +} + +fn main() { + let u = Union { f2: 255 }; + let u2 = Union2 { name: [1] }; + + println!("Hi"); // set breakpoint here +} -- 2.30.2