mirror of
				https://github.com/k3s-io/kubernetes.git
				synced 2025-10-30 21:30:16 +00:00 
			
		
		
		
	Commit e3ed3ba7c9 bumps golang/mock to 1.6.0 in hack/tools.
It makes sense to keep its version in sync, so let's do the same
in the top level go.mod.
Generated by
	./hack/pin-dependency.sh github.com/golang/mock v1.6.0
	./hack/lint-dependencies.sh
	./hack/update-vendor.sh
	./hack/update-internal-modules.sh
Signed-off-by: Kir Kolyshkin <kolyshkin@gmail.com>
		
	
		
			
				
	
	
		
			114 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			114 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2011 Google Inc.
 | |
| //
 | |
| // Licensed under the Apache License, Version 2.0 (the "License");
 | |
| // you may not use this file except in compliance with the License.
 | |
| // You may obtain a copy of the License at
 | |
| //
 | |
| //     http://www.apache.org/licenses/LICENSE-2.0
 | |
| //
 | |
| // Unless required by applicable law or agreed to in writing, software
 | |
| // distributed under the License is distributed on an "AS IS" BASIS,
 | |
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | |
| // See the License for the specific language governing permissions and
 | |
| // limitations under the License.
 | |
| 
 | |
| package gomock
 | |
| 
 | |
| import (
 | |
| 	"bytes"
 | |
| 	"errors"
 | |
| 	"fmt"
 | |
| )
 | |
| 
 | |
| // callSet represents a set of expected calls, indexed by receiver and method
 | |
| // name.
 | |
| type callSet struct {
 | |
| 	// Calls that are still expected.
 | |
| 	expected map[callSetKey][]*Call
 | |
| 	// Calls that have been exhausted.
 | |
| 	exhausted map[callSetKey][]*Call
 | |
| }
 | |
| 
 | |
| // callSetKey is the key in the maps in callSet
 | |
| type callSetKey struct {
 | |
| 	receiver interface{}
 | |
| 	fname    string
 | |
| }
 | |
| 
 | |
| func newCallSet() *callSet {
 | |
| 	return &callSet{make(map[callSetKey][]*Call), make(map[callSetKey][]*Call)}
 | |
| }
 | |
| 
 | |
| // Add adds a new expected call.
 | |
| func (cs callSet) Add(call *Call) {
 | |
| 	key := callSetKey{call.receiver, call.method}
 | |
| 	m := cs.expected
 | |
| 	if call.exhausted() {
 | |
| 		m = cs.exhausted
 | |
| 	}
 | |
| 	m[key] = append(m[key], call)
 | |
| }
 | |
| 
 | |
| // Remove removes an expected call.
 | |
| func (cs callSet) Remove(call *Call) {
 | |
| 	key := callSetKey{call.receiver, call.method}
 | |
| 	calls := cs.expected[key]
 | |
| 	for i, c := range calls {
 | |
| 		if c == call {
 | |
| 			// maintain order for remaining calls
 | |
| 			cs.expected[key] = append(calls[:i], calls[i+1:]...)
 | |
| 			cs.exhausted[key] = append(cs.exhausted[key], call)
 | |
| 			break
 | |
| 		}
 | |
| 	}
 | |
| }
 | |
| 
 | |
| // FindMatch searches for a matching call. Returns error with explanation message if no call matched.
 | |
| func (cs callSet) FindMatch(receiver interface{}, method string, args []interface{}) (*Call, error) {
 | |
| 	key := callSetKey{receiver, method}
 | |
| 
 | |
| 	// Search through the expected calls.
 | |
| 	expected := cs.expected[key]
 | |
| 	var callsErrors bytes.Buffer
 | |
| 	for _, call := range expected {
 | |
| 		err := call.matches(args)
 | |
| 		if err != nil {
 | |
| 			_, _ = fmt.Fprintf(&callsErrors, "\n%v", err)
 | |
| 		} else {
 | |
| 			return call, nil
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	// If we haven't found a match then search through the exhausted calls so we
 | |
| 	// get useful error messages.
 | |
| 	exhausted := cs.exhausted[key]
 | |
| 	for _, call := range exhausted {
 | |
| 		if err := call.matches(args); err != nil {
 | |
| 			_, _ = fmt.Fprintf(&callsErrors, "\n%v", err)
 | |
| 			continue
 | |
| 		}
 | |
| 		_, _ = fmt.Fprintf(
 | |
| 			&callsErrors, "all expected calls for method %q have been exhausted", method,
 | |
| 		)
 | |
| 	}
 | |
| 
 | |
| 	if len(expected)+len(exhausted) == 0 {
 | |
| 		_, _ = fmt.Fprintf(&callsErrors, "there are no expected calls of the method %q for that receiver", method)
 | |
| 	}
 | |
| 
 | |
| 	return nil, errors.New(callsErrors.String())
 | |
| }
 | |
| 
 | |
| // Failures returns the calls that are not satisfied.
 | |
| func (cs callSet) Failures() []*Call {
 | |
| 	failures := make([]*Call, 0, len(cs.expected))
 | |
| 	for _, calls := range cs.expected {
 | |
| 		for _, call := range calls {
 | |
| 			if !call.satisfied() {
 | |
| 				failures = append(failures, call)
 | |
| 			}
 | |
| 		}
 | |
| 	}
 | |
| 	return failures
 | |
| }
 |