[v2] Fix for PR gdb/17017

Message ID CAGyQ6gzjKs9AzVaA6cAkV9JOGR4FDtRaR5zrNJfj7A8N-MijAw@mail.gmail.com
State New, archived
Headers

Commit Message

Siva Chandra Reddy June 5, 2014, 10:55 p.m. UTC
  The attached patch fixes PR 17017 along the lines suggested by Pedro
here: https://sourceware.org/ml/gdb-patches/2014-06/msg00212.html

ChangeLog:

2014-06-05  Siva Chandra Reddy  <sivachandra@google.com>

        testsuite/

        PR gdb/17017
        * gdb.python/py-xmethods.cc: Add global function call counters and
        increment them in their respective functions.  Remove "cout"
        statements.
        * gdb.python/py-xmethods.exp: Make tests check the global function
        call counters instead of depending on inferior IO.
  

Comments

Pedro Alves June 6, 2014, 9:18 a.m. UTC | #1
On 06/05/2014 11:55 PM, Siva Chandra wrote:
> The attached patch fixes PR 17017 along the lines suggested by Pedro
> here: https://sourceware.org/ml/gdb-patches/2014-06/msg00212.html

Thanks!

> diff --git a/gdb/testsuite/gdb.python/py-xmethods.exp b/gdb/testsuite/gdb.python/py-xmethods.exp
> index 97b6ffa..28786ed 100644
> --- a/gdb/testsuite/gdb.python/py-xmethods.exp
> +++ b/gdb/testsuite/gdb.python/py-xmethods.exp
> @@ -40,25 +40,51 @@ gdb_breakpoint [gdb_get_line_number "Break here."]
>  gdb_continue_to_breakpoint "Break here" ".*Break here.*"
>  
>  # Tests before loading the debug methods.
> -gdb_test "p a1 + a2" "From CC <A_plus_A>.*15" "Before: a1 + a2"
> -gdb_test "p a2 - a1" "From CC <A_minus_A>.*5" "Before: a1 - a2"
> -gdb_test "p b1 - a1" "From CC <A_minus_A>.*25" "Before: b1 - a1"
> -gdb_test "p a1.geta()" "From CC A::geta.*5" "Before: a1.geta()"
> +if {[get_integer_valueof "a1 + a2" 0] != 15
> +    || [get_integer_valueof "a_plus_a" 0] != 1} { 
> +    fail "Before: a1 + a2" 

Shouldn't we have corresponding PASSes ?

> +}

> +if {[get_integer_valueof "a2 - a1" 0] != 5
> +    || [get_integer_valueof "a_minus_a" 0] != 1} { 
> +    fail "Before: a2 - a1"
> +}
> +if {[get_integer_valueof "b1 - a1" 0] != 25
> +    || [get_integer_valueof "a_minus_a" 0] != 2} { 

Hmm, looks like these reads of "a_minus_a" etc. will cause
several duplicated gdb.sum lines.  You can wrap tests with
with_test_prefix to address that:

with_test_prefix "Before: b1 - a1" {
...
}

See:

https://sourceware.org/gdb/wiki/GDBTestcaseCookbook#Make_sure_test_messages_are_unique

Thanks,
  

Patch

diff --git a/gdb/testsuite/gdb.python/py-xmethods.cc b/gdb/testsuite/gdb.python/py-xmethods.cc
index 96637d8..96389fd 100644
--- a/gdb/testsuite/gdb.python/py-xmethods.cc
+++ b/gdb/testsuite/gdb.python/py-xmethods.cc
@@ -15,10 +15,6 @@ 
    You should have received a copy of the GNU General Public License
    along with this program.  If not, see  <http://www.gnu.org/licenses/>.  */
 
-#include <iostream>
-
-using namespace std;
-
 namespace dop
 {
 
@@ -35,24 +31,30 @@  public:
 
 A::~A () { }
 
+int a_plus_a = 0;
+
 int
 A::operator+ (const A &obj)
 {
-  cout << "From CC <A_plus_A>:" << endl;
+  a_plus_a++;
   return a + obj.a;
 }
 
+int a_minus_a = 0;
+
 int
 A::operator- (const A &obj)
 {
-  cout << "From CC <A_minus_A>:" << endl;
+  a_minus_a++;
   return a - obj.a;
 }
 
+int a_geta = 0;
+
 int
 A::geta (void)
 {
-  cout << "From CC A::geta:" << endl;
+  a_geta++;
   return a;
 }
 
@@ -62,10 +64,12 @@  public:
   virtual int geta (void);
 };
 
+int b_geta = 0;
+
 int
 B::geta (void)
 {
-  cout << "From CC B::geta:" << endl;
+  b_geta++;
   return 2 * a;
 }
 
@@ -100,30 +104,36 @@  class G
   T t;
 };
 
+int g_size_diff = 0;
+
 template <typename T>
 template <typename T1>
 int
 G<T>::size_diff ()
 {
-  cout << "From CC G<>::size_diff:" << endl;
+  g_size_diff++;
   return sizeof (T1) - sizeof (T);
 }
 
+int g_size_mul = 0;
+
 template <typename T>
 template <int M>
 int
 G<T>::size_mul ()
 {
-  cout << "From CC G<>::size_mul:" << endl;
+  g_size_mul++;
   return M * sizeof (T);
 }
 
+int g_mul = 0;
+
 template <typename T>
 template <typename T1>
 T
 G<T>::mul (const T1 t1)
 {
-  cout << "From CC G<>::mul:" << endl;
+  g_mul++;
   return t1 * t;
 }
 
diff --git a/gdb/testsuite/gdb.python/py-xmethods.exp b/gdb/testsuite/gdb.python/py-xmethods.exp
index 97b6ffa..28786ed 100644
--- a/gdb/testsuite/gdb.python/py-xmethods.exp
+++ b/gdb/testsuite/gdb.python/py-xmethods.exp
@@ -40,25 +40,51 @@  gdb_breakpoint [gdb_get_line_number "Break here."]
 gdb_continue_to_breakpoint "Break here" ".*Break here.*"
 
 # Tests before loading the debug methods.
-gdb_test "p a1 + a2" "From CC <A_plus_A>.*15" "Before: a1 + a2"
-gdb_test "p a2 - a1" "From CC <A_minus_A>.*5" "Before: a1 - a2"
-gdb_test "p b1 - a1" "From CC <A_minus_A>.*25" "Before: b1 - a1"
-gdb_test "p a1.geta()" "From CC A::geta.*5" "Before: a1.geta()"
+if {[get_integer_valueof "a1 + a2" 0] != 15
+    || [get_integer_valueof "a_plus_a" 0] != 1} { 
+    fail "Before: a1 + a2" 
+}
+if {[get_integer_valueof "a2 - a1" 0] != 5
+    || [get_integer_valueof "a_minus_a" 0] != 1} { 
+    fail "Before: a2 - a1"
+}
+if {[get_integer_valueof "b1 - a1" 0] != 25
+    || [get_integer_valueof "a_minus_a" 0] != 2} { 
+    fail "Before: b1 - a1"
+}
+if {[get_integer_valueof "a1.geta()" 0] != 5
+    || [get_integer_valueof "a_geta" 0] != 1} { 
+    fail "Before: a1.geta()"
+}
 gdb_test "p ++a1" "No symbol.*" "Before: ++a1"
 gdb_test "p a1.getarrayind(5)" "Couldn't find method.*" \
   "Before: a1.getarrayind(5)"
-gdb_test "p a_ptr->geta()" "From CC B::geta.*60" "Before: a_ptr->geta()"
-gdb_test "p e.geta()" "From CC A::geta.*100" "Before: e.geta()"
-gdb_test "p g.size_diff<float>()" "From CC G<>::size_diff.*" \
-  "Before: g.size_diff<float>()"
+if {[get_integer_valueof "a_ptr->geta()" 0] != 60
+    || [get_integer_valueof "b_geta" 0] != 1} { 
+    fail "Before: a_ptr.geta()"
+}
+if {[get_integer_valueof "e.geta()" 0] != 100
+    || [get_integer_valueof "a_geta" 0] != 2} { 
+    fail "Before: e.geta()"
+}
+# Since g.size_diff operates of sizes of int and float, do not check for
+# actual result value as it could be different on different platforms.
+gdb_test "p g.size_diff<float>()" ".*" "Before: call g.size_diff<float>()"
+if {[get_integer_valueof "g_size_diff" 0] != 2} { 
+    fail "Before: g.size_diff<float>()"
+}
 gdb_test "p g.size_diff<unsigned long>()" "Couldn't find method.*" \
   "Before: g.size_diff<unsigned long>()"
-gdb_test "p g.size_mul<2>()" "From CC G<>::size_mul.*" \
-  "Before: g.size_mul<2>()"
+if {[get_integer_valueof "g.size_mul<2>()" 0] == 0
+    || [get_integer_valueof "g_size_mul" 0] != 2} { 
+    fail "Before: g.size_mul<2>()"
+}
 gdb_test "p g.size_mul<5>()" "Couldn't find method.*" \
   "Before: g.size_mul<5>()"
-gdb_test "p g.mul<double>(2.0)" "From CC G<>::mul.*" \
-  "Before: g.mul<double>(2.0)"
+if {[get_integer_valueof "g.mul<double>(2.0)" 0] != 10
+    || [get_integer_valueof "g_mul" 0] != 2} { 
+    fail "Before: g.mul<double>(2.0)"
+}
 gdb_test "p g.mul<char>('a')" "Couldn't find method.*" \
   "Before: g.mul<char>('a')"
 
@@ -67,9 +93,15 @@  gdb_test_no_output "source ${xmethods_script}" "load the script file"
 
 # Tests after loading debug methods.
 gdb_test "p a1 + a2" "From Python <A_plus_A>.*15" "After: a1 + a2"
-gdb_test "p a2 - a1" "From CC <A_minus_A>.*5" "After: a1 - a2"
+if {[get_integer_valueof "a2 - a1" 0] != 5
+    || [get_integer_valueof "a_minus_a" 0] != 3} { 
+    fail "Before: a2 - a1"
+}
 gdb_test "p b1 + a1" "From Python <A_plus_A>.*35" "After: b1 + a1"
-gdb_test "p b1 - a1" "From CC <A_minus_A>.*25" "After: b1 - a1"
+if {[get_integer_valueof "b1 - a1" 0] != 25
+    || [get_integer_valueof "a_minus_a" 0] != 4} { 
+    fail "Before: b1 - a1"
+}
 gdb_test "p a1.geta()" "From Python <A_geta>.*5" "After: a1.geta()"
 gdb_test "p ++a1" "From Python <plus_plus_A>.*6" "After: ++a1"
 gdb_test "p a1.getarrayind(5)" "From Python <A_getarrayind>.*5" \