2017-10-02 18:47:10 +01:00
|
|
|
#!/bin/bash
|
2017-10-23 18:06:02 +01:00
|
|
|
set +o posix
|
2017-10-02 18:47:10 +01:00
|
|
|
|
|
|
|
echo "Starting API Diff"
|
|
|
|
|
2017-10-03 12:51:55 +01:00
|
|
|
APIHOME=$(dirname $0)
|
|
|
|
|
|
|
|
apiCurrent=$APIHOME/api-current.txt
|
2017-10-02 18:47:10 +01:00
|
|
|
if [ ! -f $apiCurrent ]; then
|
2017-10-03 12:51:55 +01:00
|
|
|
echo "Missing $apiCurrent file - cannot check API diff. Please rebase or add it to this release"
|
2017-10-02 18:47:10 +01:00
|
|
|
exit -1
|
|
|
|
fi
|
|
|
|
|
2017-10-12 11:39:22 +01:00
|
|
|
# Remove the two header lines from the diff output.
|
2018-11-22 20:30:37 +00:00
|
|
|
diffContents=`diff --minimal -u $apiCurrent $APIHOME/../build/api/api-corda-*.txt | tail -n +3`
|
2017-10-12 11:39:22 +01:00
|
|
|
echo "Diff contents:"
|
2017-10-02 18:47:10 +01:00
|
|
|
echo "$diffContents"
|
2017-10-09 17:38:45 +01:00
|
|
|
echo
|
|
|
|
|
|
|
|
# A removed line means that an API was either deleted or modified.
|
2017-10-12 11:39:22 +01:00
|
|
|
removals=$(echo "$diffContents" | grep "^-")
|
2017-10-09 17:38:45 +01:00
|
|
|
removalCount=`grep -v "^$" <<EOF | wc -l
|
|
|
|
$removals
|
|
|
|
EOF
|
|
|
|
`
|
|
|
|
|
|
|
|
echo "Number of API removals/changes: "$removalCount
|
|
|
|
if [ $removalCount -gt 0 ]; then
|
|
|
|
echo "$removals"
|
|
|
|
echo
|
|
|
|
fi
|
|
|
|
|
|
|
|
# Adding new abstract methods could also break the API.
|
2018-02-14 16:42:56 +00:00
|
|
|
# However, first exclude classes marked with the @DoNotImplement annotation
|
2017-10-19 17:18:35 +01:00
|
|
|
function forUserImpl() {
|
|
|
|
awk '/DoNotImplement/,/^##/{ next }{ print }' $1
|
|
|
|
}
|
|
|
|
|
2017-10-23 18:06:02 +01:00
|
|
|
userDiffContents=`diff -u <(forUserImpl $apiCurrent) <(forUserImpl $APIHOME/../build/api/api-corda-*.txt) | tail -n +3`
|
2017-10-19 17:18:35 +01:00
|
|
|
|
|
|
|
newAbstracts=$(echo "$userDiffContents" | grep "^+" | grep "\(public\|protected\) abstract")
|
2017-10-09 17:38:45 +01:00
|
|
|
abstractCount=`grep -v "^$" <<EOF | wc -l
|
|
|
|
$newAbstracts
|
|
|
|
EOF
|
|
|
|
`
|
|
|
|
|
2019-01-07 15:02:32 +00:00
|
|
|
# Get a list of any methods that expose internal classes, which includes:
|
|
|
|
# - classes in .internal. namespaces (excluding the kotlin.jvm.internal namespace)
|
|
|
|
# - classes which extend/implement an internal class (see above)
|
|
|
|
# - classes in the net.corda.node. namespace
|
2018-02-28 13:26:49 +00:00
|
|
|
#TODO: check that only classes in a whitelist are part of the API rather than look for specific invalid cases going forward
|
2019-01-07 15:02:32 +00:00
|
|
|
newInternalExposures=$(echo "$userDiffContents" | grep "^+" | grep "(?<!kotlin\.jvm)\.internal\." )
|
2018-05-21 13:05:08 +03:00
|
|
|
newNodeExposures=$(echo "$userDiffContents" | grep "^+" | grep "net\.corda\.node\.")
|
2018-02-14 16:42:56 +00:00
|
|
|
|
|
|
|
internalCount=`grep -v "^$" <<EOF | wc -l
|
|
|
|
$newInternalExposures
|
2018-02-28 13:26:49 +00:00
|
|
|
$newNodeExposures
|
2018-02-14 16:42:56 +00:00
|
|
|
EOF
|
|
|
|
`
|
|
|
|
|
|
|
|
echo "Number of new internal class exposures: "$internalCount
|
|
|
|
if [ $internalCount -gt 0 ]; then
|
|
|
|
echo "$newInternalExposures"
|
2018-02-28 13:26:49 +00:00
|
|
|
echo "$newNodeExposures"
|
2018-02-14 16:42:56 +00:00
|
|
|
echo
|
|
|
|
fi
|
|
|
|
|
2017-10-09 17:38:45 +01:00
|
|
|
echo "Number of new abstract APIs: "$abstractCount
|
|
|
|
if [ $abstractCount -gt 0 ]; then
|
|
|
|
echo "$newAbstracts"
|
|
|
|
echo
|
|
|
|
fi
|
|
|
|
|
2018-02-14 16:42:56 +00:00
|
|
|
badChanges=$(($removalCount + $abstractCount + $internalCount))
|
2017-11-06 11:54:48 +00:00
|
|
|
if [ $badChanges -gt 255 ]; then
|
|
|
|
echo "OVERFLOW! Number of bad API changes: $badChanges"
|
|
|
|
badChanges=255
|
|
|
|
fi
|
2017-10-09 17:38:45 +01:00
|
|
|
|
|
|
|
echo "Exiting with exit code" $badChanges
|
|
|
|
exit $badChanges
|