Major New features
* New and updated search functions using xpath, api-path and instance-id
* New search functions using api-path and instance_id:
* C search functions: `clixon_find_instance_id()` and `clixon_find_api_path()`
* Binary search optimization in lists for indexed leafs in all three formats.
* This improves search performance to O(logN) which is drastical improvements for large lists.
* You can also register explicit indexes for making binary search (not only list keys)
* For more info, see docs at [paths](https://clixon-docs.readthedocs.io/en/latest/paths.html) and
[search](https://clixon-docs.readthedocs.io/en/latest/xml.html#searching-in-xml)
API changes on existing features (you may need to change your code)
* On failed validation of leafrefs, error message changed from: `No such leaf` to `No leaf <name> matching path <path>`.
* CLI Error message (clicon_rpc_generate_error()) changed when backend returns netconf error to be more descriptive:
* Original: `Config error: Validate failed. Edit and try again or discard changes: Invalid argument`
* New (example): `Netconf error: application operation-failed Identityref validation failed, undefined not derived from acl-base . Validate failed. Edit and try again or discard changes"
Minor changes
* Test framework
* Added `-- -S <file>` command-line to main example to be able to return any state to main example.
* Added `test/cicd` test scripts for running on a set of other hosts
* C-code restructuring
* clixon_yang.c partitioned and moved code into clixon_yang_parse_lib.c and clixon_yang_module.c and move back some code from clixon_yang_type.c.
* partly to reduce size, but most important to limit code that accesses internal yang structures, only clixon_yang.c does this now.
32 lines
900 B
Bash
Executable file
32 lines
900 B
Bash
Executable file
#!/usr/bin/env bash
|
|
# Test: XML performance test
|
|
# See https://github.com/clicon/clixon/issues/96
|
|
# Magic line must be first in script (see README.md)
|
|
s="$_" ; . ./lib.sh || if [ "$s" = $0 ]; then exit 0; else return 0; fi
|
|
|
|
: ${clixon_util_xml:="clixon_util_xml"}
|
|
|
|
# Number of list/leaf-list entries in file
|
|
: ${perfnr:=30000}
|
|
|
|
fxml=$dir/long.xml
|
|
|
|
new "generate long file $fxml"
|
|
echo -n "<rpc-reply><stdout><![CDATA[" > $fxml
|
|
for (( i=0; i<$perfnr; i++ )); do
|
|
echo "*>i10.0.0.$i/32 10.255.0.20 0 100 0 i" >> $fxml
|
|
done
|
|
echo "]]></stdout></rpc-reply>" >> $fxml
|
|
|
|
# 32-bit i386:
|
|
#0.37user 1.94system 0:02.47elapsed 93%CPU (0avgtext+0avgdata 9336maxresident)k
|
|
#256inputs+0outputs (2major+2049minor)pagefaults 0swa
|
|
new "xml parse long CDATA"
|
|
expecteof_file "time $clixon_util_xml" 0 "$fxml"
|
|
|
|
rm -rf $dir
|
|
|
|
# unset conditional parameters
|
|
unset clixon_util_xml
|
|
unset perfnr
|
|
|