1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00

Merge pull request #10439 from jcarrano/ensure-value

makefile/utils: Add a function for checking that a string is not empty.
This commit is contained in:
Gaëtan Harter 2018-12-07 19:17:37 +01:00 committed by GitHub
commit 5a2609c573
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 90 additions and 0 deletions

11
makefiles/utils/checks.mk Normal file
View File

@ -0,0 +1,11 @@
# Utilities to produce errors inside Make
# Use this functions to produce friendlier error messages.
# Produce an error if the value is empty
#
# Parameters
# value: a string which should not be empty
# message: The error message to display.
# Returns:
# the first argument, if it is not empty.
ensure_value = $(if $(1),$(1),$(error $(2)))

View File

@ -0,0 +1,7 @@
include checks.mk
test-ensure_value:
@test "$@" = "$(call ensure_value,$@,"This should not fail")"
test-ensure_value-negative:
@echo $(call ensure_value,$^,"This should fail")

View File

@ -0,0 +1,33 @@
BOARD_WHITELIST = native
include ../Makefile.tests_common
include $(RIOTBASE)/Makefile.include
# Test utils commands
define command_should_fail
$1 2>/dev/null && { echo "Command '$1' should have failed but did not" >&2; $1; exit 1; } || true
endef
define command_should_succeed
$1 || { echo "Command '$1' failed" >&2; $1; exit 1; }
endef
MAKEFILES_UTILS = $(RIOTMAKE)/utils
TESTS = test-ensure_value test-ensure_value-negative
# Tests will be run both in the host machine and in `docker`
all: build-system-utils-tests
build-system-utils-tests: $(TESTS)
.PHONY: build-system-utils-tests $(TESTS)
# tests for 'ensure_value'
test-ensure_value:
$(Q)$(call command_should_succeed,"$(MAKE)" -C $(MAKEFILES_UTILS) -f test-checks.mk test-ensure_value)
test-ensure_value-negative:
$(Q)$(call command_should_fail,"$(MAKE)" -C $(MAKEFILES_UTILS) -f test-checks.mk test-ensure_value-negative)

View File

@ -0,0 +1,14 @@
Build system utils tests
========================
This test checks the build system 'utils' functions declared in
`makefiles/utils`.
The test output says nothing in case of success.
Note
----
It should not be necessary to compile but this simplifies the integration in
murdock for the moment. Also there will be other tests that may need to check
the result of the compilation.

View File

@ -0,0 +1,25 @@
/*
* Copyright (C) 2018 Freie Universität Berlin
*
* This file is subject to the terms and conditions of the GNU Lesser General
* Public License v2.1. See the file LICENSE in the top level directory for more
* details.
*/
/**
* @ingroup tests
* @{
*
* @file
* @brief Empty main file
*
* @author Gaëtan Harter <gaetan.harter@fu-berlin.de>
*
* @}
*/
int main(void)
{
/* The important rules are in the Makefile */
return 0;
}