* Use Deskflow Name * Remove business-oriented options from issue templates * Remove business-oriented workflow * Bump version to 3.0.0 (to avoid confusion with previously used version numbers 1.x & 2.x) * Update readme to reflect new project name and goals * Found some more "synergy" to rename * Rename `synlib` to `app` * Rename `syntool` to `deskflow-legacy` * Rename `synwinhk` to `dfwhook` * Rename dirs from synergy to deskflow * Rename more "Synergy" files * Rename app bundle ID * Fixed copyright typo * Rename only title in serial key dialog (to be moved downstream later) * Preserve original serial key window for moving downstream * Restore dialogs ready for moving downstream * Rename `QDeskflowApplication` to `DeskflowApplication` (the Q is confusing) * Restore Volker's original project name * Fixed mimetype * Fixed weird grammar * Fixed (more) weird grammar * Broken link, restoring (but we should move all links out of source) * Broken link, restoring (but we should move all links out of source) * Add write permission to valgrind-analysis.yml * Restore AUR conflicts * Apply Clang format * Update ChangeLog * Back out version change --------- Co-authored-by: Nick Bolton <nick@symless.com>
83 lines
2.4 KiB
Python
Executable File
83 lines
2.4 KiB
Python
Executable File
#!/usr/bin/env python3
|
|
|
|
# Deskflow -- mouse and keyboard sharing utility
|
|
# Copyright (C) 2024 Symless Ltd.
|
|
#
|
|
# This package is free software; you can redistribute it and/or
|
|
# modify it under the terms of the GNU General Public License
|
|
# found in the file LICENSE that should have accompanied this file.
|
|
#
|
|
# This package 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/>.
|
|
|
|
import lib.env as env
|
|
|
|
env.ensure_in_venv(__file__)
|
|
|
|
import argparse, os, sys
|
|
import lib.cmd_utils as cmd_utils
|
|
import lib.colors as colors
|
|
|
|
valgrind_bin = "valgrind"
|
|
|
|
|
|
def main():
|
|
parser = argparse.ArgumentParser()
|
|
parser.add_argument("--unit-tests", action="store_true")
|
|
parser.add_argument("--integ-tests", action="store_true")
|
|
parser.add_argument(
|
|
"--filter-file",
|
|
type=str,
|
|
help="Takes the base filename without extension and uses it as a filter",
|
|
)
|
|
parser.add_argument(
|
|
"--ignore-return-code",
|
|
action="store_true",
|
|
help="Ignore the return code of the test command",
|
|
)
|
|
parser.add_argument(
|
|
"--valgrind",
|
|
action="store_true",
|
|
help="Run the test command with valgrind",
|
|
)
|
|
|
|
args = parser.parse_args()
|
|
binary = get_binary_path(args)
|
|
|
|
if args.filter_file:
|
|
file_base = os.path.basename(args.filter_file)
|
|
without_ext = os.path.splitext(file_base)[0]
|
|
command = [binary, f"--gtest_filter={without_ext}*"]
|
|
else:
|
|
command = [binary]
|
|
|
|
if args.valgrind:
|
|
if not cmd_utils.has_command(valgrind_bin):
|
|
print(f"{colors.ERROR_TEXT} {valgrind_bin} not found")
|
|
sys.exit(1)
|
|
|
|
command = [valgrind_bin] + command
|
|
|
|
result = cmd_utils.run(command, print_cmd=True, check=False)
|
|
if not args.ignore_return_code:
|
|
sys.exit(result.returncode)
|
|
|
|
|
|
def get_binary_path(args):
|
|
base_dir = "./build/bin"
|
|
if args.unit_tests:
|
|
return f"{base_dir}/unittests"
|
|
elif args.integ_tests:
|
|
return f"{base_dir}/integtests"
|
|
else:
|
|
raise RuntimeError("No test type specified")
|
|
|
|
|
|
if __name__ == "__main__":
|
|
main()
|