mirror of
https://github.com/opentffoundation/opentf.git
synced 2026-01-16 02:00:51 -05:00
This changeset performs the following: - Updates `masterzen/winrm` vendor to include change from (https://github.com/masterzen/winrm/pull/73) - Updates `dylanmei/winrmtest` vendor to include change from (https://github.com/dylanmei/winrmtest/pull/4) - Updates `packer-community/winrmcp` vendor to include the removal of the `masterzen/winrm/winrm` sub-class as a result of the `winrm` CLI tool being removed from the `masterzen/winrm` repository. - Changes `communicator/winrm/communicator.go` to conform to the new ABI in the `masterzen/winrm` library. This should completely remove any LGPL licensed dependencies inside of the Terraform project. ``` $ make test ==> Checking that code complies with gofmt requirements... go generate $(go list ./... | grep -v /terraform/vendor/) 2017/08/20 13:40:16 Generated command/internal_plugin_list.go go test -i $(go list ./... | grep -v '/terraform/vendor/' | grep -v '/builtin/bins/') || exit 1 echo $(go list ./... | grep -v '/terraform/vendor/' | grep -v '/builtin/bins/') | \ xargs -t -n4 go test -timeout=60s -parallel=4 go test -timeout=60s -parallel=4 github.com/hashicorp/terraform github.com/hashicorp/terraform/backend github.com/hashicorp/terraform/backend/atlas github.com/hashicorp/terraform/backend/init ok github.com/hashicorp/terraform 0.011s ok github.com/hashicorp/terraform/backend 0.020s ok github.com/hashicorp/terraform/backend/atlas 0.634s ok github.com/hashicorp/terraform/backend/init 0.007s go test -timeout=60s -parallel=4 github.com/hashicorp/terraform/backend/legacy github.com/hashicorp/terraform/backend/local github.com/hashicorp/terraform/backend/remote-state github.com/hashicorp/terraf orm/backend/remote-state/azure ok github.com/hashicorp/terraform/backend/legacy 0.009s ok github.com/hashicorp/terraform/backend/local 0.211s ok github.com/hashicorp/terraform/backend/remote-state 0.006s ok github.com/hashicorp/terraform/backend/remote-state/azure 0.010s go test -timeout=60s -parallel=4 github.com/hashicorp/terraform/backend/remote-state/consul github.com/hashicorp/terraform/backend/remote-state/inmem github.com/hashicorp/terraform/backend/remote-state/s 3 github.com/hashicorp/terraform/backend/remote-state/swift ok github.com/hashicorp/terraform/backend/remote-state/consul 0.007s ok github.com/hashicorp/terraform/backend/remote-state/inmem 0.013s ok github.com/hashicorp/terraform/backend/remote-state/s3 0.007s ok github.com/hashicorp/terraform/backend/remote-state/swift 0.013s go test -timeout=60s -parallel=4 github.com/hashicorp/terraform/builtin/providers/test github.com/hashicorp/terraform/builtin/provisioners/chef github.com/hashicorp/terraform/builtin/provisioners/file gi thub.com/hashicorp/terraform/builtin/provisioners/local-exec ok github.com/hashicorp/terraform/builtin/providers/test 1.544s ok github.com/hashicorp/terraform/builtin/provisioners/chef 0.017s ok github.com/hashicorp/terraform/builtin/provisioners/file 0.006s ok github.com/hashicorp/terraform/builtin/provisioners/local-exec 0.078s go test -timeout=60s -parallel=4 github.com/hashicorp/terraform/builtin/provisioners/remote-exec github.com/hashicorp/terraform/builtin/provisioners/salt-masterless github.com/hashicorp/terraform/command github.com/hashicorp/terraform/command/clistate ok github.com/hashicorp/terraform/builtin/provisioners/remote-exec 1.037s ok github.com/hashicorp/terraform/builtin/provisioners/salt-masterless 0.008s ok github.com/hashicorp/terraform/command 14.589s ? github.com/hashicorp/terraform/command/clistate [no test files] go test -timeout=60s -parallel=4 github.com/hashicorp/terraform/command/e2etest github.com/hashicorp/terraform/command/format github.com/hashicorp/terraform/communicator github.com/hashicorp/terraform/co mmunicator/remote ok github.com/hashicorp/terraform/command/e2etest 3.729s ok github.com/hashicorp/terraform/command/format 0.004s ok github.com/hashicorp/terraform/communicator 0.005s ok github.com/hashicorp/terraform/communicator/remote 0.003s [no tests to run] go test -timeout=60s -parallel=4 github.com/hashicorp/terraform/communicator/shared github.com/hashicorp/terraform/communicator/ssh github.com/hashicorp/terraform/communicator/winrm github.com/hashicorp/ terraform/config ok github.com/hashicorp/terraform/communicator/shared 0.007s ok github.com/hashicorp/terraform/communicator/ssh 0.016s ok github.com/hashicorp/terraform/communicator/winrm 0.018s ok github.com/hashicorp/terraform/config 0.213s go test -timeout=60s -parallel=4 github.com/hashicorp/terraform/config/module github.com/hashicorp/terraform/dag github.com/hashicorp/terraform/digraph github.com/hashicorp/terraform/flatmap ok github.com/hashicorp/terraform/config/module 0.044s ok github.com/hashicorp/terraform/dag 0.010s ok github.com/hashicorp/terraform/digraph 0.002s ok github.com/hashicorp/terraform/flatmap 0.002s go test -timeout=60s -parallel=4 github.com/hashicorp/terraform/helper/acctest github.com/hashicorp/terraform/helper/config github.com/hashicorp/terraform/helper/copy github.com/hashicorp/terraform/helpe r/diff ? github.com/hashicorp/terraform/helper/acctest [no test files] ok github.com/hashicorp/terraform/helper/config 0.005s ? github.com/hashicorp/terraform/helper/copy [no test files] ok github.com/hashicorp/terraform/helper/diff 0.005s go test -timeout=60s -parallel=4 github.com/hashicorp/terraform/helper/encryption github.com/hashicorp/terraform/helper/experiment github.com/hashicorp/terraform/helper/hashcode github.com/hashicorp/terr aform/helper/hilmapstructure ? github.com/hashicorp/terraform/helper/encryption [no test files] ok github.com/hashicorp/terraform/helper/experiment 0.001s ok github.com/hashicorp/terraform/helper/hashcode 0.001s ? github.com/hashicorp/terraform/helper/hilmapstructure [no test files] go test -timeout=60s -parallel=4 github.com/hashicorp/terraform/helper/logging github.com/hashicorp/terraform/helper/mutexkv github.com/hashicorp/terraform/helper/pathorcontents github.com/hashicorp/terr aform/helper/resource ? github.com/hashicorp/terraform/helper/logging [no test files] ok github.com/hashicorp/terraform/helper/mutexkv 0.055s ok github.com/hashicorp/terraform/helper/pathorcontents 0.002s ok github.com/hashicorp/terraform/helper/resource 2.659s go test -timeout=60s -parallel=4 github.com/hashicorp/terraform/helper/schema github.com/hashicorp/terraform/helper/shadow github.com/hashicorp/terraform/helper/signalwrapper github.com/hashicorp/terrafo rm/helper/slowmessage ok github.com/hashicorp/terraform/helper/schema 0.063s ok github.com/hashicorp/terraform/helper/shadow 0.156s ok github.com/hashicorp/terraform/helper/signalwrapper 0.022s ok github.com/hashicorp/terraform/helper/slowmessage 0.102s go test -timeout=60s -parallel=4 github.com/hashicorp/terraform/helper/structure github.com/hashicorp/terraform/helper/validation github.com/hashicorp/terraform/helper/variables github.com/hashicorp/terr aform/helper/wrappedreadline ok github.com/hashicorp/terraform/helper/structure 0.004s ok github.com/hashicorp/terraform/helper/validation 0.004s ok github.com/hashicorp/terraform/helper/variables 0.006s ? github.com/hashicorp/terraform/helper/wrappedreadline [no test files] go test -timeout=60s -parallel=4 github.com/hashicorp/terraform/helper/wrappedstreams github.com/hashicorp/terraform/moduledeps github.com/hashicorp/terraform/plugin github.com/hashicorp/terraform/plugin /discovery ? github.com/hashicorp/terraform/helper/wrappedstreams [no test files] ok github.com/hashicorp/terraform/moduledeps 0.004s ok github.com/hashicorp/terraform/plugin 0.046s ok github.com/hashicorp/terraform/plugin/discovery 0.029s go test -timeout=60s -parallel=4 github.com/hashicorp/terraform/repl github.com/hashicorp/terraform/scripts github.com/hashicorp/terraform/state github.com/hashicorp/terraform/state/remote ok github.com/hashicorp/terraform/repl 0.006s ok github.com/hashicorp/terraform/scripts 0.008s ok github.com/hashicorp/terraform/state 2.617s ok github.com/hashicorp/terraform/state/remote 0.025s go test -timeout=60s -parallel=4 github.com/hashicorp/terraform/terraform github.com/hashicorp/terraform/tools/terraform-bundle go test -timeout=60s -parallel=4 github.com/hashicorp/terraform/terraform github.com/hashicorp/terraform/tools/terraform-bundle ok github.com/hashicorp/terraform/terraform 4.222s ? github.com/hashicorp/terraform/tools/terraform-bundle [no test files] ```
255 lines
5.5 KiB
Go
255 lines
5.5 KiB
Go
package xpath
|
|
|
|
import (
|
|
"errors"
|
|
"strconv"
|
|
"strings"
|
|
)
|
|
|
|
// The XPath function list.
|
|
|
|
func predicate(q query) func(NodeNavigator) bool {
|
|
type Predicater interface {
|
|
Test(NodeNavigator) bool
|
|
}
|
|
if p, ok := q.(Predicater); ok {
|
|
return p.Test
|
|
}
|
|
return func(NodeNavigator) bool { return true }
|
|
}
|
|
|
|
// positionFunc is a XPath Node Set functions position().
|
|
func positionFunc(q query, t iterator) interface{} {
|
|
var (
|
|
count = 1
|
|
node = t.Current()
|
|
)
|
|
test := predicate(q)
|
|
for node.MoveToPrevious() {
|
|
if test(node) {
|
|
count++
|
|
}
|
|
}
|
|
return float64(count)
|
|
}
|
|
|
|
// lastFunc is a XPath Node Set functions last().
|
|
func lastFunc(q query, t iterator) interface{} {
|
|
var (
|
|
count = 0
|
|
node = t.Current()
|
|
)
|
|
node.MoveToFirst()
|
|
test := predicate(q)
|
|
for {
|
|
if test(node) {
|
|
count++
|
|
}
|
|
if !node.MoveToNext() {
|
|
break
|
|
}
|
|
}
|
|
return float64(count)
|
|
}
|
|
|
|
// countFunc is a XPath Node Set functions count(node-set).
|
|
func countFunc(q query, t iterator) interface{} {
|
|
var count = 0
|
|
test := predicate(q)
|
|
switch typ := q.Evaluate(t).(type) {
|
|
case query:
|
|
for node := typ.Select(t); node != nil; node = typ.Select(t) {
|
|
if test(node) {
|
|
count++
|
|
}
|
|
}
|
|
}
|
|
return float64(count)
|
|
}
|
|
|
|
// sumFunc is a XPath Node Set functions sum(node-set).
|
|
func sumFunc(q query, t iterator) interface{} {
|
|
var sum float64
|
|
switch typ := q.Evaluate(t).(type) {
|
|
case query:
|
|
for node := typ.Select(t); node != nil; node = typ.Select(t) {
|
|
if v, err := strconv.ParseFloat(node.Value(), 64); err == nil {
|
|
sum += v
|
|
}
|
|
}
|
|
case float64:
|
|
sum = typ
|
|
case string:
|
|
if v, err := strconv.ParseFloat(typ, 64); err != nil {
|
|
sum = v
|
|
}
|
|
}
|
|
return sum
|
|
}
|
|
|
|
// nameFunc is a XPath functions name([node-set]).
|
|
func nameFunc(q query, t iterator) interface{} {
|
|
return t.Current().LocalName()
|
|
}
|
|
|
|
// startwithFunc is a XPath functions starts-with(string, string).
|
|
func startwithFunc(arg1, arg2 query) func(query, iterator) interface{} {
|
|
return func(q query, t iterator) interface{} {
|
|
var (
|
|
m, n string
|
|
ok bool
|
|
)
|
|
switch typ := arg1.Evaluate(t).(type) {
|
|
case string:
|
|
m = typ
|
|
case query:
|
|
node := typ.Select(t)
|
|
if node == nil {
|
|
return false
|
|
}
|
|
m = node.Value()
|
|
default:
|
|
panic(errors.New("starts-with() function argument type must be string"))
|
|
}
|
|
n, ok = arg2.Evaluate(t).(string)
|
|
if !ok {
|
|
panic(errors.New("starts-with() function argument type must be string"))
|
|
}
|
|
return strings.HasPrefix(m, n)
|
|
}
|
|
}
|
|
|
|
// containsFunc is a XPath functions contains(string or @attr, string).
|
|
func containsFunc(arg1, arg2 query) func(query, iterator) interface{} {
|
|
return func(q query, t iterator) interface{} {
|
|
var (
|
|
m, n string
|
|
ok bool
|
|
)
|
|
|
|
switch typ := arg1.Evaluate(t).(type) {
|
|
case string:
|
|
m = typ
|
|
case query:
|
|
node := typ.Select(t)
|
|
if node == nil {
|
|
return false
|
|
}
|
|
m = node.Value()
|
|
default:
|
|
panic(errors.New("contains() function argument type must be string"))
|
|
}
|
|
|
|
n, ok = arg2.Evaluate(t).(string)
|
|
if !ok {
|
|
panic(errors.New("contains() function argument type must be string"))
|
|
}
|
|
|
|
return strings.Contains(m, n)
|
|
}
|
|
}
|
|
|
|
// normalizespaceFunc is XPath functions normalize-space(string?)
|
|
func normalizespaceFunc(q query, t iterator) interface{} {
|
|
var m string
|
|
switch typ := q.Evaluate(t).(type) {
|
|
case string:
|
|
m = typ
|
|
case query:
|
|
node := typ.Select(t)
|
|
if node == nil {
|
|
return false
|
|
}
|
|
m = node.Value()
|
|
}
|
|
return strings.TrimSpace(m)
|
|
}
|
|
|
|
// substringFunc is XPath functions substring function returns a part of a given string.
|
|
func substringFunc(arg1, arg2, arg3 query) func(query, iterator) interface{} {
|
|
return func(q query, t iterator) interface{} {
|
|
var m string
|
|
switch typ := arg1.Evaluate(t).(type) {
|
|
case string:
|
|
m = typ
|
|
case query:
|
|
node := typ.Select(t)
|
|
if node == nil {
|
|
return false
|
|
}
|
|
m = node.Value()
|
|
}
|
|
|
|
var start, length float64
|
|
var ok bool
|
|
|
|
if start, ok = arg2.Evaluate(t).(float64); !ok {
|
|
panic(errors.New("substring() function first argument type must be int"))
|
|
}
|
|
if arg3 != nil {
|
|
if length, ok = arg3.Evaluate(t).(float64); !ok {
|
|
panic(errors.New("substring() function second argument type must be int"))
|
|
}
|
|
}
|
|
if (len(m) - int(start)) < int(length) {
|
|
panic(errors.New("substring() function start and length argument out of range"))
|
|
}
|
|
if length > 0 {
|
|
return m[int(start):int(length+start)]
|
|
}
|
|
return m[int(start):]
|
|
}
|
|
}
|
|
|
|
// stringLengthFunc is XPATH string-length( [string] ) function that returns a number
|
|
// equal to the number of characters in a given string.
|
|
func stringLengthFunc(arg1 query) func(query, iterator) interface{} {
|
|
return func(q query, t iterator) interface{} {
|
|
switch v := arg1.Evaluate(t).(type) {
|
|
case string:
|
|
return float64(len(v))
|
|
case query:
|
|
node := v.Select(t)
|
|
if node == nil {
|
|
break
|
|
}
|
|
return float64(len(node.Value()))
|
|
}
|
|
return float64(0)
|
|
}
|
|
}
|
|
|
|
// notFunc is XPATH functions not(expression) function operation.
|
|
func notFunc(q query, t iterator) interface{} {
|
|
switch v := q.Evaluate(t).(type) {
|
|
case bool:
|
|
return !v
|
|
case query:
|
|
node := v.Select(t)
|
|
return node == nil
|
|
default:
|
|
return false
|
|
}
|
|
}
|
|
|
|
// concatFunc is the concat function concatenates two or more
|
|
// strings and returns the resulting string.
|
|
// concat( string1 , string2 [, stringn]* )
|
|
func concatFunc(args ...query) func(query, iterator) interface{} {
|
|
return func(q query, t iterator) interface{} {
|
|
var a []string
|
|
for _, v := range args {
|
|
switch v := v.Evaluate(t).(type) {
|
|
case string:
|
|
a = append(a, v)
|
|
case query:
|
|
node := v.Select(t)
|
|
if node != nil {
|
|
a = append(a, node.Value())
|
|
}
|
|
}
|
|
}
|
|
return strings.Join(a, "")
|
|
}
|
|
}
|