--- /dev/null
+/* This testcase is part of GDB, the GNU debugger.
+
+   Copyright 2021 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 <http://www.gnu.org/licenses/>.  */
+
+int
+main ()
+{
+  return 0;
+}
 
 
 set do_xml_test [expr ![gdb_skip_xml_test]]
 
-gdb_start
-
-set test "maintenance selftest"
-gdb_test_multiple $test $test {
-  -re ".*Running selftest \[^\n\r\]+\." {
-       # The selftests can take some time to complete.  To prevent
-       # timeout spot the 'Running ...' lines going past, so long as
-       # these are produced quickly enough then the overall test will
-       # not timeout.
-       exp_continue
-  }
-  -re "Ran ($decimal) unit tests, 0 failed\r\n$gdb_prompt $" {
-       set num_ran $expect_out(1,string)
-       gdb_assert "$num_ran > 0" $test
-  }
-
-  -re "Selftests have been disabled for this build.\r\n$gdb_prompt $" {
-       unsupported $test
-  }
+standard_testfile
+
+if {[prepare_for_testing "failed to prepare" $testfile $srcfile debug]} {
+    return -1
+}
+
+proc run_selftests { binfile } {
+    global decimal gdb_prompt
+
+    if { $binfile == "" } {
+       gdb_exit
+       gdb_start
+    } else {
+       clean_restart ${binfile}
+    }
+
+    set test "maintenance selftest"
+    gdb_test_multiple $test $test {
+       -re ".*Running selftest \[^\n\r\]+\." {
+           # The selftests can take some time to complete.  To prevent
+           # timeout spot the 'Running ...' lines going past, so long as
+           # these are produced quickly enough then the overall test will
+           # not timeout.
+           exp_continue
+       }
+       -re "Ran ($decimal) unit tests, ($decimal) failed\r\n$gdb_prompt $" {
+           set num_ran $expect_out(1,string)
+           set num_failed $expect_out(2,string)
+           gdb_assert "$num_ran > 0" "$test, ran some tests"
+
+           if { $binfile != "" } {
+               # There's a known issue here (see PR gdb/27891),
+               # however, we should not have more than 1 failure.
+               gdb_assert "$num_failed <= 1" "$test, failed no more than 1"
+               setup_kfail "gdb/27891" "*-*-*"
+           }
+           gdb_assert "$num_failed == 0" "$test, failed none"
+       }
+       -re "Selftests have been disabled for this build.\r\n$gdb_prompt $" {
+           unsupported $test
+       }
+    }
+}
+
+with_test_prefix "no executable loaded" {
+    run_selftests ""
+}
+
+with_test_prefix "executable loaded" {
+    run_selftests ${binfile}
 }
 
 if { ![is_remote host] && $do_xml_test } {