Moving precommit testing scripts from Makefile[.mk] to tools/runners/run-precommit-check-for-target.sh and tools/precommit.sh; deleting Makefile.mk.
This commit is contained in:
+3
-6
@@ -145,7 +145,7 @@ project (Jerry CXX C ASM)
|
|||||||
set(COMPILE_FLAGS_JERRY "${COMPILE_FLAGS_JERRY} -Werror -Wfatal-errors")
|
set(COMPILE_FLAGS_JERRY "${COMPILE_FLAGS_JERRY} -Werror -Wfatal-errors")
|
||||||
|
|
||||||
# Static build
|
# Static build
|
||||||
set(LINKER_FLAGS_STATIC "-static")
|
set(LINKER_FLAGS_STATIC "-static")
|
||||||
|
|
||||||
# C++
|
# C++
|
||||||
set(CXX_FLAGS_JERRY "-std=c++11 -fno-exceptions -fno-rtti")
|
set(CXX_FLAGS_JERRY "-std=c++11 -fno-exceptions -fno-rtti")
|
||||||
@@ -165,11 +165,9 @@ project (Jerry CXX C ASM)
|
|||||||
|
|
||||||
# Debug
|
# Debug
|
||||||
set(FLAGS_COMMON_DEBUG "-nostdlib")
|
set(FLAGS_COMMON_DEBUG "-nostdlib")
|
||||||
set(LINKER_FLAGS_COMMON_DEBUG "-nostdlib")
|
|
||||||
|
|
||||||
# Release
|
# Release
|
||||||
set(FLAGS_COMMON_RELEASE "-Os -flto -nostdlib")
|
set(FLAGS_COMMON_RELEASE "-Os -flto -nostdlib")
|
||||||
set(LINKER_FLAGS_COMMON_RELEASE "-nostdlib")
|
|
||||||
|
|
||||||
# Unit tests
|
# Unit tests
|
||||||
set(FLAGS_COMMON_UNITTESTS "-O3 -flto -nodefaultlibs")
|
set(FLAGS_COMMON_UNITTESTS "-O3 -flto -nodefaultlibs")
|
||||||
@@ -234,7 +232,7 @@ project (Jerry CXX C ASM)
|
|||||||
|
|
||||||
function(declare_target_with_modifiers ) # modifiers are passed in ARGN implicit argument
|
function(declare_target_with_modifiers ) # modifiers are passed in ARGN implicit argument
|
||||||
set(CORE_TARGET_NAME ${BUILD_MODE_PREFIX_${BUILD_MODE}})
|
set(CORE_TARGET_NAME ${BUILD_MODE_PREFIX_${BUILD_MODE}})
|
||||||
foreach(MODIFIER ${ARGN}) # FIXME
|
foreach(MODIFIER ${ARGN})
|
||||||
set(TARGET_NAME ${TARGET_NAME}${MODIFIER_SUFFIX_${MODIFIER}})
|
set(TARGET_NAME ${TARGET_NAME}${MODIFIER_SUFFIX_${MODIFIER}})
|
||||||
|
|
||||||
set(LIBC_TARGET_NAME ${LIBC_TARGET_NAME}${MODIFIER_SUFFIX_${MODIFIER}})
|
set(LIBC_TARGET_NAME ${LIBC_TARGET_NAME}${MODIFIER_SUFFIX_${MODIFIER}})
|
||||||
@@ -306,8 +304,7 @@ project (Jerry CXX C ASM)
|
|||||||
PROPERTY COMPILE_FLAGS "${COMPILE_FLAGS_JERRY} ${CXX_FLAGS_JERRY} ${FLAGS_COMMON_UNITTESTS}")
|
PROPERTY COMPILE_FLAGS "${COMPILE_FLAGS_JERRY} ${CXX_FLAGS_JERRY} ${FLAGS_COMMON_UNITTESTS}")
|
||||||
set_property(TARGET ${TARGET_NAME}
|
set_property(TARGET ${TARGET_NAME}
|
||||||
PROPERTY LINK_FLAGS "${COMPILE_FLAGS_JERRY} ${CXX_FLAGS_JERRY} ${FLAGS_COMMON_UNITTESTS} ${LINKER_FLAGS_COMMON}")
|
PROPERTY LINK_FLAGS "${COMPILE_FLAGS_JERRY} ${CXX_FLAGS_JERRY} ${FLAGS_COMMON_UNITTESTS} ${LINKER_FLAGS_COMMON}")
|
||||||
target_compile_definitions(${TARGET_NAME} PRIVATE ${DEFINES_UNIT_TEST})
|
target_include_directories(${TARGET_NAME} PRIVATE ${INCLUDE_CORE_INTERFACE})
|
||||||
target_include_directories(${TARGET_NAME} PRIVATE ${INCLUDE_CORE})
|
|
||||||
target_link_libraries(${TARGET_NAME} ${CORE_TARGET_NAME} imported_libc imported_libgcc)
|
target_link_libraries(${TARGET_NAME} ${CORE_TARGET_NAME} imported_libc imported_libgcc)
|
||||||
|
|
||||||
add_dependencies(unittests ${TARGET_NAME})
|
add_dependencies(unittests ${TARGET_NAME})
|
||||||
|
|||||||
@@ -73,6 +73,9 @@ export OUT_DIR = ./build/bin
|
|||||||
|
|
||||||
export SHELL=/bin/bash
|
export SHELL=/bin/bash
|
||||||
|
|
||||||
|
# Precommit check targets
|
||||||
|
PRECOMMIT_CHECK_TARGETS_LIST := debug.linux release.linux
|
||||||
|
|
||||||
# Building all options combinations
|
# Building all options combinations
|
||||||
OPTIONS_COMBINATIONS := $(foreach __OPTION,ON OFF,$(__COMBINATION)-VALGRIND-$(__OPTION))
|
OPTIONS_COMBINATIONS := $(foreach __OPTION,ON OFF,$(__COMBINATION)-VALGRIND-$(__OPTION))
|
||||||
# OPTIONS_COMBINATIONS := $(foreach __COMBINATION,$(OPTIONS_COMBINATIONS),$(foreach __OPTION,ON OFF,$(__COMBINATION)-{ANOTHER_OPTION}-$(__OPTION)))
|
# OPTIONS_COMBINATIONS := $(foreach __COMBINATION,$(OPTIONS_COMBINATIONS),$(foreach __OPTION,ON OFF,$(__COMBINATION)-{ANOTHER_OPTION}-$(__OPTION)))
|
||||||
@@ -106,17 +109,20 @@ $(BUILD_DIRS_NATIVE):
|
|||||||
fi; \
|
fi; \
|
||||||
mkdir -p $@ && \
|
mkdir -p $@ && \
|
||||||
cd $@ && \
|
cd $@ && \
|
||||||
cmake -DENABLE_VALGRIND=$(VALGRIND) -DCMAKE_TOOLCHAIN_FILE=build/configs/toolchain_linux_$$arch.cmake ../../.. &>cmake.log
|
cmake -DENABLE_VALGRIND=$(VALGRIND) -DCMAKE_TOOLCHAIN_FILE=build/configs/toolchain_linux_$$arch.cmake ../../.. &>cmake.log || \
|
||||||
|
(echo "CMake run failed. See "`pwd`"/cmake.log for details."; exit 1;)
|
||||||
|
|
||||||
$(BUILD_DIRS_STM32F3):
|
$(BUILD_DIRS_STM32F3):
|
||||||
@ mkdir -p $@ && \
|
@ mkdir -p $@ && \
|
||||||
cd $@ && \
|
cd $@ && \
|
||||||
cmake -DENABLE_VALGRIND=$(VALGRIND) -DCMAKE_TOOLCHAIN_FILE=build/configs/toolchain_mcu_stm32f3.cmake ../../.. &>cmake.log
|
cmake -DENABLE_VALGRIND=$(VALGRIND) -DCMAKE_TOOLCHAIN_FILE=build/configs/toolchain_mcu_stm32f3.cmake ../../.. &>cmake.log || \
|
||||||
|
(echo "CMake run failed. See "`pwd`"/cmake.log for details."; exit 1;)
|
||||||
|
|
||||||
$(BUILD_DIRS_STM32F4):
|
$(BUILD_DIRS_STM32F4):
|
||||||
@ mkdir -p $@ && \
|
@ mkdir -p $@ && \
|
||||||
cd $@ && \
|
cd $@ && \
|
||||||
cmake -DENABLE_VALGRIND=$(VALGRIND) -DCMAKE_TOOLCHAIN_FILE=build/configs/toolchain_mcu_stm32f4.cmake ../../.. &>cmake.log
|
cmake -DENABLE_VALGRIND=$(VALGRIND) -DCMAKE_TOOLCHAIN_FILE=build/configs/toolchain_mcu_stm32f4.cmake ../../.. &>cmake.log || \
|
||||||
|
(echo "CMake run failed. See "`pwd`"/cmake.log for details."; exit 1;)
|
||||||
|
|
||||||
$(JERRY_LINUX_TARGETS): $(BUILD_DIR)/native
|
$(JERRY_LINUX_TARGETS): $(BUILD_DIR)/native
|
||||||
@ mkdir -p $(OUT_DIR)/$@
|
@ mkdir -p $(OUT_DIR)/$@
|
||||||
@@ -145,13 +151,6 @@ build: $(JERRY_TARGETS) unittests
|
|||||||
$(FLASH_TARGETS): $(BUILD_DIR)/mcu
|
$(FLASH_TARGETS): $(BUILD_DIR)/mcu
|
||||||
@$(MAKE) -C $(BUILD_DIR)/mcu VERBOSE=1 $@ 1>/dev/null
|
@$(MAKE) -C $(BUILD_DIR)/mcu VERBOSE=1 $@ 1>/dev/null
|
||||||
|
|
||||||
PRECOMMIT_CHECK_TARGETS_NO_VALGRIND_LIST= debug.linux.check \
|
|
||||||
release.linux.check
|
|
||||||
|
|
||||||
PRECOMMIT_CHECK_TARGETS_VALGRIND_LIST= #debug.linux-valgrind.check \
|
|
||||||
release.linux-valgrind.check \
|
|
||||||
release.linux-cp-valgrind.check
|
|
||||||
|
|
||||||
push: ./tools/git-scripts/push.sh
|
push: ./tools/git-scripts/push.sh
|
||||||
@ ./tools/git-scripts/push.sh
|
@ ./tools/git-scripts/push.sh
|
||||||
|
|
||||||
@@ -162,65 +161,13 @@ log: ./tools/git-scripts/log.sh
|
|||||||
@ ./tools/git-scripts/log.sh
|
@ ./tools/git-scripts/log.sh
|
||||||
|
|
||||||
precommit: clean
|
precommit: clean
|
||||||
@ echo -e "\nBuilding...\n\n"
|
@ ./tools/precommit.sh "$(MAKE)" "$(OUT_DIR)" "$(PRECOMMIT_CHECK_TARGETS_LIST)"
|
||||||
@ $(MAKE) build
|
|
||||||
@ echo -e "\n================ Build completed successfully. Running precommit tests ================\n"
|
|
||||||
@ echo -e "All targets were built successfully. Starting unit tests' run.\n"
|
|
||||||
@ $(MAKE) unittests_run TESTS_OPTS="--silent"
|
|
||||||
@ echo -e "Unit tests completed successfully. Starting parse-only testing.\n"
|
|
||||||
@ echo -e "All targets were built successfully. Starting parse-only testing.\n"
|
|
||||||
@ # Parse-only testing
|
|
||||||
@ for path in "./tests/jerry" "./tests/benchmarks/jerry"; \
|
|
||||||
do \
|
|
||||||
run_ids=""; \
|
|
||||||
for check_target in $(PRECOMMIT_CHECK_TARGETS_NO_VALGRIND_LIST) $(PRECOMMIT_CHECK_TARGETS_VALGRIND_LIST); \
|
|
||||||
do \
|
|
||||||
$(MAKE) -s -f Makefile.mk TARGET=$$check_target $$check_target TESTS="$$path" TESTS_OPTS="--parse-only" OUTPUT_TO_LOG=enable & \
|
|
||||||
run_ids="$$run_ids $$!"; \
|
|
||||||
done; \
|
|
||||||
result_ok=1; \
|
|
||||||
for run_id in $$run_ids; \
|
|
||||||
do \
|
|
||||||
wait $$run_id || result_ok=0; \
|
|
||||||
done; \
|
|
||||||
[ $$result_ok -eq 1 ] || exit 1; \
|
|
||||||
done
|
|
||||||
@ echo -e "Parse-only testing completed successfully. Starting full tests run.\n"
|
|
||||||
@ # Full testing
|
|
||||||
@ for path in "./tests/jerry"; \
|
|
||||||
do \
|
|
||||||
run_ids=""; \
|
|
||||||
for check_target in $(PRECOMMIT_CHECK_TARGETS_NO_VALGRIND_LIST) $(PRECOMMIT_CHECK_TARGETS_VALGRIND_LIST); \
|
|
||||||
do \
|
|
||||||
$(MAKE) -s -f Makefile.mk TARGET=$$check_target $$check_target TESTS="$$path" TESTS_OPTS="" OUTPUT_TO_LOG=enable & \
|
|
||||||
run_ids="$$run_ids $$!"; \
|
|
||||||
done; \
|
|
||||||
result_ok=1; \
|
|
||||||
for run_id in $$run_ids; \
|
|
||||||
do \
|
|
||||||
wait $$run_id || result_ok=0; \
|
|
||||||
done; \
|
|
||||||
[ $$result_ok -eq 1 ] || exit 1; \
|
|
||||||
done
|
|
||||||
@ for path in "./tests/jerry-test-suite/precommit_test_list"; \
|
|
||||||
do \
|
|
||||||
run_ids=""; \
|
|
||||||
for check_target in $(PRECOMMIT_CHECK_TARGETS_NO_VALGRIND_LIST); \
|
|
||||||
do \
|
|
||||||
$(MAKE) -s -f Makefile.mk TARGET=$$check_target $$check_target TESTS="$$path" TESTS_OPTS="" OUTPUT_TO_LOG=enable & \
|
|
||||||
run_ids="$$run_ids $$!"; \
|
|
||||||
done; \
|
|
||||||
result_ok=1; \
|
|
||||||
for run_id in $$run_ids; \
|
|
||||||
do \
|
|
||||||
wait $$run_id || result_ok=0; \
|
|
||||||
done; \
|
|
||||||
[ $$result_ok -eq 1 ] || exit 1; \
|
|
||||||
done
|
|
||||||
@ echo -e "Full testing completed successfully\n\n================\n\n"
|
|
||||||
|
|
||||||
unittests_run: unittests
|
unittests_run: unittests
|
||||||
@$(MAKE) -s -f Makefile.mk TARGET=$@ $@
|
@rm -rf $(OUT_DIR)/unittests/check
|
||||||
|
@mkdir -p $(OUT_DIR)/unittests/check
|
||||||
|
@./tools/runners/run-unittests.sh $(OUT_DIR)/unittests || \
|
||||||
|
(echo "Unit tests run failed. See $(OUT_DIR)/unittests/unit_tests_run.log for details."; exit 1;)
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
@ rm -rf $(BUILD_DIR_PREFIX)* $(OUT_DIR)
|
@ rm -rf $(BUILD_DIR_PREFIX)* $(OUT_DIR)
|
||||||
|
|||||||
-98
@@ -1,98 +0,0 @@
|
|||||||
export SHELL=/bin/bash
|
|
||||||
|
|
||||||
ifeq ($(TARGET),)
|
|
||||||
$(error TARGET not set)
|
|
||||||
endif
|
|
||||||
|
|
||||||
ENGINE_NAME ?= jerry
|
|
||||||
|
|
||||||
# Parsing target
|
|
||||||
# '.' -> ' '
|
|
||||||
TARGET_SPACED := $(subst ., ,$(TARGET))
|
|
||||||
# extract target mode part
|
|
||||||
TARGET_MODE := $(word 1,$(TARGET_SPACED))
|
|
||||||
# extract target system part with modifiers
|
|
||||||
TARGET_SYSTEM_AND_MODS := $(word 2,$(TARGET_SPACED))
|
|
||||||
TARGET_SYSTEM_AND_MODS_SPACED := $(subst -, ,$(TARGET_SYSTEM_AND_MODS))
|
|
||||||
|
|
||||||
# extract target system part
|
|
||||||
TARGET_SYSTEM := $(word 1,$(TARGET_SYSTEM_AND_MODS_SPACED))
|
|
||||||
|
|
||||||
# extract modifiers
|
|
||||||
TARGET_MODS := $(wordlist 2, $(words $(TARGET_SYSTEM_AND_MODS_SPACED)), $(TARGET_SYSTEM_AND_MODS_SPACED))
|
|
||||||
|
|
||||||
# extract optional action part
|
|
||||||
TARGET_ACTION := $(word 3,$(TARGET_SPACED))
|
|
||||||
|
|
||||||
# Target used as dependency of an action (check, flash, etc.)
|
|
||||||
TARGET_OF_ACTION := $(TARGET_MODE).$(TARGET_SYSTEM_AND_MODS)
|
|
||||||
|
|
||||||
# target folder name in $(OUT_DIR)
|
|
||||||
TARGET_DIR=$(OUT_DIR)/$(TARGET_MODE).$(TARGET_SYSTEM_AND_MODS)
|
|
||||||
|
|
||||||
# unittests mode -> linux system
|
|
||||||
ifeq ($(TARGET_MODE),unittests_run)
|
|
||||||
TARGET_SYSTEM := linux
|
|
||||||
TARGET_SYSTEM_AND_MODS := $(TARGET_SYSTEM)
|
|
||||||
TARGET_DIR := $(OUT_DIR)/unittests
|
|
||||||
endif
|
|
||||||
|
|
||||||
ifeq ($(filter valgrind,$(TARGET_MODS)), valgrind)
|
|
||||||
OPTION_VALGRIND := enable
|
|
||||||
|
|
||||||
ifeq ($(OPTION_SANITIZE),enable)
|
|
||||||
$(error ASAN and Valgrind are mutually exclusive)
|
|
||||||
endif
|
|
||||||
else
|
|
||||||
OPTION_VALGRIND := disable
|
|
||||||
endif
|
|
||||||
|
|
||||||
ifeq ($(OPTION_VALGRIND),enable)
|
|
||||||
VALGRIND_CMD := "valgrind --error-exitcode=254 --track-origins=yes"
|
|
||||||
VALGRIND_TIMEOUT := 60
|
|
||||||
else
|
|
||||||
VALGRIND_CMD :=
|
|
||||||
VALGRIND_TIMEOUT :=
|
|
||||||
endif
|
|
||||||
|
|
||||||
.PHONY: unittests_run $(CHECK_TARGETS)
|
|
||||||
|
|
||||||
unittests_run:
|
|
||||||
@ VALGRIND=$(VALGRIND_CMD) ./tools/runners/run-unittests.sh $(TARGET_DIR) $(TESTS_OPTS)
|
|
||||||
|
|
||||||
$(CHECK_TARGETS):
|
|
||||||
@ if [ ! -f $(TARGET_DIR)/$(ENGINE_NAME) ]; then echo $(TARGET_OF_ACTION) is not built yet; exit 1; fi;
|
|
||||||
@ if [[ ! -d "$(TESTS)" && ! -f "$(TESTS)" ]]; then echo \"$(TESTS)\" is not a directory and not a file; exit 1; fi;
|
|
||||||
@ rm -rf $(TARGET_DIR)/check
|
|
||||||
@ mkdir -p $(TARGET_DIR)/check
|
|
||||||
@ if [ "$(OUTPUT_TO_LOG)" = "enable" ]; \
|
|
||||||
then \
|
|
||||||
ADD_OPTS="--output-to-log"; \
|
|
||||||
fi; \
|
|
||||||
VALGRIND=$(VALGRIND_CMD) TIMEOUT=$(VALGRIND_TIMEOUT) ./tools/runners/run-test-pass.sh $(TARGET_DIR)/$(ENGINE_NAME) $(TARGET_DIR)/check $(TESTS) $(TESTS_OPTS) $$ADD_OPTS; \
|
|
||||||
status_code=$$?; \
|
|
||||||
if [ $$status_code -ne 0 ]; \
|
|
||||||
then \
|
|
||||||
echo $(TARGET) failed; \
|
|
||||||
if [ "$(OUTPUT_TO_LOG)" = "enable" ]; \
|
|
||||||
then \
|
|
||||||
echo See log in $(TARGET_DIR)/check directory for details.; \
|
|
||||||
fi; \
|
|
||||||
\
|
|
||||||
exit $$status_code; \
|
|
||||||
fi; \
|
|
||||||
if [ -d $(TESTS_DIR)/fail/ ]; \
|
|
||||||
then \
|
|
||||||
VALGRIND=$(VALGRIND_CMD) TIMEOUT=$(VALGRIND_TIMEOUT) ./tools/runners/run-test-xfail.sh $(TARGET_DIR)/$(ENGINE_NAME) $(TARGET_DIR)/check $(PARSER_ERROR_CODE) $(TESTS_DIR) $(TESTS_OPTS) $$ADD_OPTS; \
|
|
||||||
status_code=$$?; \
|
|
||||||
if [ $$status_code -ne 0 ]; \
|
|
||||||
then \
|
|
||||||
echo $(TARGET) failed; \
|
|
||||||
if [ "$(OUTPUT_TO_LOG)" = "enable" ]; \
|
|
||||||
then \
|
|
||||||
echo See log in $(TARGET_DIR)/check directory for details.; \
|
|
||||||
fi; \
|
|
||||||
\
|
|
||||||
exit $$status_code; \
|
|
||||||
fi; \
|
|
||||||
fi;
|
|
||||||
Executable
+70
@@ -0,0 +1,70 @@
|
|||||||
|
# Copyright 2015 Samsung Electronics Co., Ltd.
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
|
||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
MAKE="$1"
|
||||||
|
shift
|
||||||
|
|
||||||
|
OUT_DIR="$1"
|
||||||
|
shift
|
||||||
|
|
||||||
|
TARGETS="$1"
|
||||||
|
shift
|
||||||
|
|
||||||
|
PARSE_ONLY_TESTING_PATHS="./tests/benchmarks/jerry"
|
||||||
|
FULL_TESTING_PATHS="./tests/jerry ./tests/jerry-test-suite/precommit_test_list"
|
||||||
|
|
||||||
|
echo -e "\nBuilding...\n\n"
|
||||||
|
$MAKE build || exit 1
|
||||||
|
echo -e "\n================ Build completed successfully. Running precommit tests ================\n"
|
||||||
|
echo -e "All targets were built successfully. Starting unit tests' run.\n"
|
||||||
|
$MAKE unittests_run || exit 1
|
||||||
|
echo -e "Unit tests completed successfully. Starting full testing.\n"
|
||||||
|
|
||||||
|
RUN_IDS=""
|
||||||
|
|
||||||
|
for TARGET in $TARGETS
|
||||||
|
do
|
||||||
|
ENGINE=$OUT_DIR/$TARGET/jerry
|
||||||
|
LOGS_PATH_PARSE_ONLY=$OUT_DIR/$TARGET/check_parse_only
|
||||||
|
LOGS_PATH_FULL=$OUT_DIR/$TARGET/check
|
||||||
|
|
||||||
|
# Parse-only testing
|
||||||
|
INDEX=0
|
||||||
|
for TESTS_PATH in "./tests/benchmarks/jerry"
|
||||||
|
do
|
||||||
|
./tools/runners/run-precommit-check-for-target.sh $ENGINE $LOGS_PATH_PARSE_ONLY/$INDEX $TESTS_PATH --parse-only &
|
||||||
|
RUN_IDS="$RUN_IDS $!";
|
||||||
|
INDEX=$((INDEX + 1))
|
||||||
|
done
|
||||||
|
|
||||||
|
# Full testing
|
||||||
|
INDEX=0
|
||||||
|
for TESTS_PATH in "./tests/jerry" "./tests/jerry-test-suite/precommit_test_list"
|
||||||
|
do
|
||||||
|
./tools/runners/run-precommit-check-for-target.sh $ENGINE $LOGS_PATH_FULL/$INDEX $TESTS_PATH &
|
||||||
|
RUN_IDS="$RUN_IDS $!";
|
||||||
|
INDEX=$((INDEX + 1))
|
||||||
|
done
|
||||||
|
done
|
||||||
|
|
||||||
|
RESULT_OK=1
|
||||||
|
for RUN_ID in $RUN_IDS
|
||||||
|
do
|
||||||
|
wait $RUN_ID || RESULT_OK=0
|
||||||
|
done;
|
||||||
|
[ $RESULT_OK -eq 1 ] || exit 1
|
||||||
|
|
||||||
|
echo -e "Full testing completed successfully\n\n================\n\n"
|
||||||
+49
@@ -0,0 +1,49 @@
|
|||||||
|
# Copyright 2015 Samsung Electronics Co., Ltd.
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
|
||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
ENGINE_PATH="$1"
|
||||||
|
OUTPUT_PATH="$2"
|
||||||
|
TESTS_PATH="$3"
|
||||||
|
TESTS_OPTS="$4"
|
||||||
|
|
||||||
|
[ -x $ENGINE_PATH ] || exit 1
|
||||||
|
[[ -d $TESTS_PATH || -f $TESTS_PATH ]] || exit 1
|
||||||
|
mkdir -p $OUTPUT_PATH || exit 1
|
||||||
|
|
||||||
|
./tools/runners/run-test-pass.sh $ENGINE_PATH $OUTPUT_PATH $TESTS_PATH $TESTS_OPTS --output-to-log; status_code=$?
|
||||||
|
if [ $status_code -ne 0 ]
|
||||||
|
then
|
||||||
|
echo "$ENGINE_PATH testing failed"
|
||||||
|
echo "See log in $OUTPUT_PATH directory for details."
|
||||||
|
exit $status_code
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -d $TESTS_PATH/fail ]
|
||||||
|
then
|
||||||
|
for error_code in `cd $TESTS_PATH/fail && ls -d [0-9]*`
|
||||||
|
do
|
||||||
|
./tools/runners/run-test-xfail.sh $ENGINE_PATH $OUTPUT_PATH $error_code $TESTS_PATH $TESTS_OPTS --output-to-log; status_code=$?
|
||||||
|
|
||||||
|
if [ $status_code -ne 0 ]
|
||||||
|
then
|
||||||
|
echo "$ENGINE_PATH testing failed"
|
||||||
|
echo "See log in $OUTPUT_PATH directory for details."
|
||||||
|
exit $status_code
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
fi
|
||||||
|
|
||||||
|
exit 0
|
||||||
@@ -74,15 +74,13 @@ passed=0
|
|||||||
|
|
||||||
JERRY_TEMP=jerry.tmp
|
JERRY_TEMP=jerry.tmp
|
||||||
|
|
||||||
exec 2>/dev/null
|
|
||||||
|
|
||||||
echo " Passed / Failed / Tested / Total / Percent"
|
echo " Passed / Failed / Tested / Total / Percent"
|
||||||
|
|
||||||
for test in `cat $JS_FILES`
|
for test in `cat $JS_FILES`
|
||||||
do
|
do
|
||||||
percent=$(echo $tested*100/$total | bc)
|
percent=$(echo $tested*100/$total | bc)
|
||||||
|
|
||||||
( ulimit -t $TIMEOUT; $VALGRIND ${ENGINE} ${JERRY_ARGS} ${test} >&$JERRY_TEMP; exit $? );
|
( ulimit -t $TIMEOUT; ${ENGINE} ${JERRY_ARGS} ${test} &>$JERRY_TEMP; exit $? );
|
||||||
status_code=$?
|
status_code=$?
|
||||||
|
|
||||||
if [ $ECHO_PROGRESS -eq 1 ]
|
if [ $ECHO_PROGRESS -eq 1 ]
|
||||||
@@ -108,7 +106,7 @@ do
|
|||||||
tested=$((tested+1))
|
tested=$((tested+1))
|
||||||
done
|
done
|
||||||
|
|
||||||
rm $JERRY_TEMP
|
rm -f $JERRY_TEMP
|
||||||
|
|
||||||
printf "\r\e[2K[ %6d / %6d / %6d / %5d / %3d%% ]\n" ${passed} ${failed} ${tested} ${total} ${percent}
|
printf "\r\e[2K[ %6d / %6d / %6d / %5d / %3d%% ]\n" ${passed} ${failed} ${tested} ${total} ${percent}
|
||||||
|
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
# Copyright 2014 Samsung Electronics Co., Ltd.
|
# Copyright 2014-2015 Samsung Electronics Co., Ltd.
|
||||||
#
|
#
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
# you may not use this file except in compliance with the License.
|
# you may not use this file except in compliance with the License.
|
||||||
@@ -82,15 +82,13 @@ passed=0
|
|||||||
|
|
||||||
JERRY_TEMP=jerry.tmp
|
JERRY_TEMP=jerry.tmp
|
||||||
|
|
||||||
exec 2>/dev/null
|
|
||||||
|
|
||||||
echo " Passed / Failed / Tested / Total / Percent"
|
echo " Passed / Failed / Tested / Total / Percent"
|
||||||
|
|
||||||
for test in `cat $JS_FILES`
|
for test in `cat $JS_FILES`
|
||||||
do
|
do
|
||||||
percent=$(echo $tested*100/$total | bc)
|
percent=$(echo $tested*100/$total | bc)
|
||||||
|
|
||||||
( ulimit -t $TIMEOUT; $VALGRIND ${ENGINE} ${test} ${JERRY_ARGS} >&$JERRY_TEMP; exit $? );
|
( ulimit -t $TIMEOUT; ${ENGINE} ${test} ${JERRY_ARGS} >&$JERRY_TEMP; exit $? );
|
||||||
status_code=$?
|
status_code=$?
|
||||||
|
|
||||||
if [ $ECHO_PROGRESS -eq 1 ]
|
if [ $ECHO_PROGRESS -eq 1 ]
|
||||||
|
|||||||
@@ -36,7 +36,7 @@ for unit_test in $UNITTESTS;
|
|||||||
do
|
do
|
||||||
[ $OPTION_SILENT = "enable" ] || echo -n "Running $unit_test... ";
|
[ $OPTION_SILENT = "enable" ] || echo -n "Running $unit_test... ";
|
||||||
|
|
||||||
$VALGRIND $unit_test >&$DIR/unit_tests_run.log.tmp;
|
$unit_test >&$DIR/unit_tests_run.log.tmp;
|
||||||
status_code=$?
|
status_code=$?
|
||||||
cat $DIR/unit_tests_run.log.tmp >> $DIR/unit_tests_run.log
|
cat $DIR/unit_tests_run.log.tmp >> $DIR/unit_tests_run.log
|
||||||
rm $DIR/unit_tests_run.log.tmp
|
rm $DIR/unit_tests_run.log.tmp
|
||||||
@@ -49,4 +49,3 @@ do
|
|||||||
exit 1;
|
exit 1;
|
||||||
fi;
|
fi;
|
||||||
done
|
done
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user