summaryrefslogtreecommitdiffstats
path: root/cps-path-parser/src/test
diff options
context:
space:
mode:
authorsourabh_sourabh <sourabh.sourabh@est.tech>2024-07-08 17:40:38 +0100
committerSourabh Sourabh <sourabh.sourabh@est.tech>2024-07-09 15:20:30 +0000
commit8f3103dd1eaf5d537cd085dd8fab5ef39d7d914d (patch)
treeb75ea2ae5bb23be19f6642b23548f07f06884f86 /cps-path-parser/src/test
parent735cc72cdf706de32e4b55848da1d5242ba1be26 (diff)
NCMP: NCMP search API fixed to handle cps path that is ancestor axis as
well - Cps path builder is fixed to handle ancestor axis that is target as well while quering. Issue-ID: CPS-2308 Change-Id: Iaf215851ada17d21516ae83fa142ac77ff1c6c19 Signed-off-by: sourabh_sourabh <sourabh.sourabh@est.tech>
Diffstat (limited to 'cps-path-parser/src/test')
-rw-r--r--cps-path-parser/src/test/groovy/org/onap/cps/cpspath/parser/CpsPathQuerySpec.groovy19
1 files changed, 18 insertions, 1 deletions
diff --git a/cps-path-parser/src/test/groovy/org/onap/cps/cpspath/parser/CpsPathQuerySpec.groovy b/cps-path-parser/src/test/groovy/org/onap/cps/cpspath/parser/CpsPathQuerySpec.groovy
index ae7ee598ab..15f6b11823 100644
--- a/cps-path-parser/src/test/groovy/org/onap/cps/cpspath/parser/CpsPathQuerySpec.groovy
+++ b/cps-path-parser/src/test/groovy/org/onap/cps/cpspath/parser/CpsPathQuerySpec.groovy
@@ -1,6 +1,6 @@
/*
* ============LICENSE_START=======================================================
- * Copyright (C) 2021-2023 Nordix Foundation
+ * Copyright (C) 2021-2024 Nordix Foundation
* Modifications Copyright (C) 2023 TechMahindra Ltd
* ================================================================================
* Licensed under the Apache License, Version 2.0 (the "License");
@@ -253,4 +253,21 @@ class CpsPathQuerySpec extends Specification {
'/test[@name2="value2" and @name1="value1"]' || 'name2' | 'name1'
}
+ def 'Ancestor axis matching prefix'() {
+ when: 'building a cps path query'
+ def result = parseXPathAndBuild(xpath)
+ then: 'ancestor axis is removed when same as prefix'
+ assert result.hasAncestorAxis() == expectAncestorAxis
+ where: 'the following xpaths are used'
+ xpath || expectAncestorAxis
+ '//abc/def/ancestor::abc' || true
+ '//abc/def/ancestor::def' || false
+ '//abc/def/ancestor::ef' || true
+ }
+
+ def parseXPathAndBuild(xpath) {
+ def cpsPathBuilder = CpsPathUtil.getCpsPathBuilder(xpath)
+ cpsPathBuilder.build()
+ }
+
}