-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathtest.sh
139 lines (118 loc) · 6.08 KB
/
test.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
#!/usr/bin/env bash
set -u -e -o pipefail
readonly currentDir=$(cd $(dirname $0); pwd)
readonly testFolder=${currentDir}/.tmp/test
readonly libFolder=${currentDir}/lib
readonly prettierFolder=${libFolder}/prettier
readonly stylelintFolder=${libFolder}/stylelint
readonly tsconfigFolder=${libFolder}/tsconfig
source ${currentDir}/scripts/ci/_ghactions-group.sh
source ${currentDir}/util-functions.sh
VERBOSE=false
TRACE=false
logInfo "============================================="
logInfo "Validation of Code-Style configurations"
for ARG in "$@"; do
case "$ARG" in
--verbose)
logInfo "============================================="
logInfo "Verbose mode enabled!"
VERBOSE=true
;;
--trace)
logInfo "============================================="
logInfo "Trace mode enabled!"
TRACE=true
;;
*)
echo "Unknown option $ARG."
exit 1
;;
esac
done
logInfo "============================================="
ghActionsGroupStart "create temporary test folder ${testFolder}" "no-xtrace"
rm -rf ${testFolder}
mkdir -p ${testFolder}
ghActionsGroupEnd "create temporary test folder ${testFolder}"
#ghActionsGroupStart "validate codelyzer configurations" "no-xtrace"
# TSLint configuration cannot be tested. See: https://github.com/palantir/tslint/issues/889
#ghActionsGroupEnd "validate codelyzer configurations"
logInfo "============================================="
logInfo "validate prettier configurations"
logInfo "============================================="
# FIXME Uncomment this once GitHub Actions support nested logs
# See: https://github.community/t5/GitHub-Actions/Feature-Request-Enhancements-to-group-commands-nested-named/m-p/45399
# ghActionsGroupStart "validate prettier configurations" "no-xtrace"
logDebug "get all prettier versions to validate"
PRETTIER_VERSIONS=($(ls ${prettierFolder} | grep "^[0-9]"))
logDebug "PRETTIER_VERSIONS: ${PRETTIER_VERSIONS[*]}"
TEMP_TEST_PRETTIER="${testFolder}/prettier-test.css"
logDebug "create temporary css file: ${TEMP_TEST_PRETTIER}"
touch ${TEMP_TEST_PRETTIER}
for PRETTIER_VERSION in ${PRETTIER_VERSIONS[@]}
do
ghActionsGroupStart "validate prettier ${PRETTIER_VERSION}" "no-xtrace"
TEMP_CONFIG_PRETTIER="${testFolder}/prettier-test-file-${PRETTIER_VERSION}.js"
logDebug "create temporary prettier config file: ${TEMP_CONFIG_PRETTIER}"
echo "module.exports=require('../../lib/prettier/${PRETTIER_VERSION}/.prettierrc.js');" > ${TEMP_CONFIG_PRETTIER}
logDebug "run command \"npx --yes prettier@${PRETTIER_VERSION} --config ${TEMP_CONFIG_PRETTIER} --write ${TEMP_TEST_PRETTIER}\""
testResult=$(npx --yes prettier@${PRETTIER_VERSION} --config ${TEMP_CONFIG_PRETTIER} --write ${TEMP_TEST_PRETTIER} 2>&1)
if [[ ${testResult} == *"[warn] Ignored unknown"* ]]; then
logInfo "The prettier configuration contains unknown rules"
die ${testResult}
fi
ghActionsGroupEnd "validate prettier ${PRETTIER_VERSION}"
done
# ghActionsGroupEnd "validate prettier configurations"
logInfo "============================================="
logInfo "validate stylelint configurations"
logInfo "============================================="
# FIXME Uncomment this once GitHub Actions support nested logs
# See: https://github.community/t5/GitHub-Actions/Feature-Request-Enhancements-to-group-commands-nested-named/m-p/45399
#ghActionsGroupStart "validate stylelint configurations" "no-xtrace"
logDebug "get all stylelint versions to validate"
STYLELINT_VERSIONS=($(ls ${stylelintFolder} | grep "^[0-9]"))
logDebug "STYLELINT_VERSIONS: ${STYLELINT_VERSIONS[*]}"
TEMP_TEST_STYLELINT="${testFolder}/stylelint-test.css"
logDebug "create temporary css file: ${TEMP_TEST_STYLELINT}"
touch ${TEMP_TEST_STYLELINT}
for STYLELINT_VERSION in ${STYLELINT_VERSIONS[@]}
do
ghActionsGroupStart "validate stylelint ${STYLELINT_VERSION}" "no-xtrace"
TEMP_CONFIG_STYLELINT="${testFolder}/stylelint-test-file-${STYLELINT_VERSION}.json"
logDebug "create temporary stylelint config file: ${TEMP_CONFIG_STYLELINT}"
echo "{\"extends\":\"../../lib/stylelint/${STYLELINT_VERSION}/stylelint.config.js\"}" > ${TEMP_CONFIG_STYLELINT}
logDebug "run command \"npx --yes stylelint@${STYLELINT_VERSION} --config ${TEMP_CONFIG_STYLELINT} ${TEMP_TEST_STYLELINT}\""
npx --yes stylelint@${STYLELINT_VERSION} --config ${TEMP_CONFIG_STYLELINT} ${TEMP_TEST_STYLELINT}
ghActionsGroupEnd "validate stylelint ${STYLELINT_VERSION}"
done
#ghActionsGroupEnd "validate stylelint configurations"
logInfo "============================================="
logInfo "validate tsconfig configurations"
logInfo "============================================="
# FIXME Uncomment this once GitHub Actions support nested logs
# See: https://github.community/t5/GitHub-Actions/Feature-Request-Enhancements-to-group-commands-nested-named/m-p/45399
#ghActionsGroupStart "validate tsconfig configurations" "no-xtrace"
logDebug "get all tsconfig versions to validate"
TSCONFIG_VERSIONS=($(ls ${tsconfigFolder} | grep "^[0-9]"))
logDebug "TSCONFIG_VERSIONS: ${TSCONFIG_VERSIONS[*]}"
TEMP_TEST_TSCONFIG="${testFolder}/tsconfig-test.ts"
logDebug "create temporary ts file: ${TEMP_TEST_TSCONFIG}"
touch ${TEMP_TEST_TSCONFIG}
for TSCONFIG_VERSION in ${TSCONFIG_VERSIONS[@]}
do
ghActionsGroupStart "validate tsconfig ${TSCONFIG_VERSION}" "no-xtrace"
TEMP_CONFIG_TSCONFIG="${testFolder}/tsconfig-test-file-${TSCONFIG_VERSION}.json"
logDebug "create temporary tsconfig file: ${TEMP_CONFIG_TSCONFIG}"
echo "{\"extends\":\"../../lib/tsconfig/${TSCONFIG_VERSION}/tsconfig.json\",\"compilerOptions\":{\"baseUrl\":\".\"}}" > ${TEMP_CONFIG_TSCONFIG}
logDebug "run command \"npx --yes -p typescript@${TSCONFIG_VERSION} -c 'tsc -p ${TEMP_CONFIG_TSCONFIG}'\""
npx --yes -p typescript@${TSCONFIG_VERSION} -c "tsc -p ${TEMP_CONFIG_TSCONFIG}"
ghActionsGroupEnd "validate tsconfig ${TSCONFIG_VERSION}"
done
#ghActionsGroupEnd "validate tsconfig configurations"
#ghActionsGroupEnd "validate tslint configurations" "no-xtrace"
# TSLint configuration cannot be tested. See: https://github.com/palantir/tslint/issues/889
#ghActionsGroupEnd "validate tslint configurations"
# Print return arrows as a log separator
ghActionsGroupReturnArrows