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.
39 lines
1.5 KiB
Bash
Executable file
39 lines
1.5 KiB
Bash
Executable file
#!/usr/bin/env bash
|
|
# CI/CD script complementing trevor github
|
|
# Login in to a number of hosts and fo the following:
|
|
# 0. Create and transfer sub-scripts used in main script: cligen-mk.sh clixon-mk.sh clixon-config.sh
|
|
# 1. pull latest version
|
|
# 2. Run configure
|
|
# 3. Compile and install (assume mk.sh)
|
|
# 4. Run tests
|
|
# Assume:
|
|
# - subscripts SCRIPTS exists locally where this script is executed
|
|
# - A test/site.sh file is handmade on each host
|
|
# - some commands are passwordless using
|
|
# sudo visudo -f /etc/sudoers.d/clixonci
|
|
# <user> ALL = (root)NOPASSWD : ALL
|
|
# <user> ALL = (www-data)NOPASSWD : ALL
|
|
# <user> ALL = (clicon)NOPASSWD : /usr/local/sbin/clixon_backend
|
|
# Experiment in identifying all commands: /usr/bin/make,/usr/local/sbin/clixon_backend,/usr/bin/pkill,/usr/local/bin/clixon_util_socket,/usr/bin/tee,/bin/rm,/usr/bin/touch,/bin/chmod
|
|
#
|
|
# Typical run: ./cicd.sh 2>&1 | tee cilog
|
|
|
|
set -eux # x
|
|
|
|
if [ $# -ne 1 ]; then
|
|
echo "usage: $0 <host>"
|
|
exit -1
|
|
fi
|
|
|
|
h=$1
|
|
|
|
ssh -t $h "test -d src/cligen || (cd src;git clone https://github.com/olofhagsand/cligen.git)"
|
|
ssh -t $h "(cd src/cligen;git pull)"
|
|
ssh -t $h "(cd src/cligen;./configure)"
|
|
ssh -t $h "(cd src/cligen; /tmp/cligen-mk.sh)"
|
|
ssh -t $h "test -d src/clixon || (cd src;git clone https://github.com/clicon/clixon.git)"
|
|
ssh -t $h "(cd src/clixon;git pull)"
|
|
ssh -t $h "(cd src/clixon; /tmp/clixon-config.sh)"
|
|
ssh -t $h "(cd src/clixon; /tmp/clixon-mk.sh)"
|
|
ssh -t $h sudo ldconfig
|
|
ssh -t $h "(cd src/clixon/test; ./sum.sh)"
|