github.com/sacloud/iaas-api-go@v1.12.0/fake/ops_load_balancer.go (about)

     1  // Copyright 2022-2023 The sacloud/iaas-api-go Authors
     2  //
     3  // Licensed under the Apache License, Version 2.0 (the "License");
     4  // you may not use this file except in compliance with the License.
     5  // You may obtain a copy of the License at
     6  //
     7  //      http://www.apache.org/licenses/LICENSE-2.0
     8  //
     9  // Unless required by applicable law or agreed to in writing, software
    10  // distributed under the License is distributed on an "AS IS" BASIS,
    11  // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    12  // See the License for the specific language governing permissions and
    13  // limitations under the License.
    14  
    15  package fake
    16  
    17  import (
    18  	"context"
    19  	"time"
    20  
    21  	"github.com/sacloud/iaas-api-go"
    22  	"github.com/sacloud/iaas-api-go/types"
    23  )
    24  
    25  // Find is fake implementation
    26  func (o *LoadBalancerOp) Find(ctx context.Context, zone string, conditions *iaas.FindCondition) (*iaas.LoadBalancerFindResult, error) {
    27  	results, _ := find(o.key, zone, conditions)
    28  	var values []*iaas.LoadBalancer
    29  	for _, res := range results {
    30  		dest := &iaas.LoadBalancer{}
    31  		copySameNameField(res, dest)
    32  		values = append(values, dest)
    33  	}
    34  	return &iaas.LoadBalancerFindResult{
    35  		Total:         len(results),
    36  		Count:         len(results),
    37  		From:          0,
    38  		LoadBalancers: values,
    39  	}, nil
    40  }
    41  
    42  // Create is fake implementation
    43  func (o *LoadBalancerOp) Create(ctx context.Context, zone string, param *iaas.LoadBalancerCreateRequest) (*iaas.LoadBalancer, error) {
    44  	result := &iaas.LoadBalancer{}
    45  	copySameNameField(param, result)
    46  	fill(result, fillID, fillCreatedAt)
    47  
    48  	result.Class = "loadbalancer"
    49  	result.Availability = types.Availabilities.Migrating
    50  	result.ZoneID = zoneIDs[zone]
    51  	result.SettingsHash = ""
    52  	for _, vip := range result.VirtualIPAddresses {
    53  		if vip.DelayLoop == 0 {
    54  			vip.DelayLoop = 10 // default value
    55  		}
    56  	}
    57  
    58  	putLoadBalancer(zone, result)
    59  
    60  	id := result.ID
    61  	startPowerOn(o.key, zone, func() (interface{}, error) {
    62  		return o.Read(context.Background(), zone, id)
    63  	})
    64  	return result, nil
    65  }
    66  
    67  // Read is fake implementation
    68  func (o *LoadBalancerOp) Read(ctx context.Context, zone string, id types.ID) (*iaas.LoadBalancer, error) {
    69  	value := getLoadBalancerByID(zone, id)
    70  	if value == nil {
    71  		return nil, newErrorNotFound(o.key, id)
    72  	}
    73  
    74  	dest := &iaas.LoadBalancer{}
    75  	copySameNameField(value, dest)
    76  	return dest, nil
    77  }
    78  
    79  // Update is fake implementation
    80  func (o *LoadBalancerOp) Update(ctx context.Context, zone string, id types.ID, param *iaas.LoadBalancerUpdateRequest) (*iaas.LoadBalancer, error) {
    81  	value, err := o.Read(ctx, zone, id)
    82  	if err != nil {
    83  		return nil, err
    84  	}
    85  
    86  	copySameNameField(param, value)
    87  	fill(value, fillModifiedAt)
    88  	for _, vip := range value.VirtualIPAddresses {
    89  		if vip.DelayLoop == 0 {
    90  			vip.DelayLoop = 10 // default value
    91  		}
    92  	}
    93  	putLoadBalancer(zone, value)
    94  	return value, nil
    95  }
    96  
    97  // UpdateSettings is fake implementation
    98  func (o *LoadBalancerOp) UpdateSettings(ctx context.Context, zone string, id types.ID, param *iaas.LoadBalancerUpdateSettingsRequest) (*iaas.LoadBalancer, error) {
    99  	value, err := o.Read(ctx, zone, id)
   100  	if err != nil {
   101  		return nil, err
   102  	}
   103  
   104  	copySameNameField(param, value)
   105  	fill(value, fillModifiedAt)
   106  	for _, vip := range value.VirtualIPAddresses {
   107  		if vip.DelayLoop == 0 {
   108  			vip.DelayLoop = 10 // default value
   109  		}
   110  	}
   111  	putLoadBalancer(zone, value)
   112  	return value, nil
   113  }
   114  
   115  // Delete is fake implementation
   116  func (o *LoadBalancerOp) Delete(ctx context.Context, zone string, id types.ID) error {
   117  	_, err := o.Read(ctx, zone, id)
   118  	if err != nil {
   119  		return err
   120  	}
   121  	ds().Delete(o.key, zone, id)
   122  	return nil
   123  }
   124  
   125  // Config is fake implementation
   126  func (o *LoadBalancerOp) Config(ctx context.Context, zone string, id types.ID) error {
   127  	_, err := o.Read(ctx, zone, id)
   128  	return err
   129  }
   130  
   131  // Boot is fake implementation
   132  func (o *LoadBalancerOp) Boot(ctx context.Context, zone string, id types.ID) error {
   133  	value, err := o.Read(ctx, zone, id)
   134  	if err != nil {
   135  		return err
   136  	}
   137  	if value.InstanceStatus.IsUp() {
   138  		return newErrorConflict(o.key, id, "Boot is failed")
   139  	}
   140  
   141  	startPowerOn(o.key, zone, func() (interface{}, error) {
   142  		return o.Read(context.Background(), zone, id)
   143  	})
   144  
   145  	return err
   146  }
   147  
   148  // Shutdown is fake implementation
   149  func (o *LoadBalancerOp) Shutdown(ctx context.Context, zone string, id types.ID, shutdownOption *iaas.ShutdownOption) error {
   150  	value, err := o.Read(ctx, zone, id)
   151  	if err != nil {
   152  		return err
   153  	}
   154  	if !value.InstanceStatus.IsUp() {
   155  		return newErrorConflict(o.key, id, "Shutdown is failed")
   156  	}
   157  
   158  	startPowerOff(o.key, zone, func() (interface{}, error) {
   159  		return o.Read(context.Background(), zone, id)
   160  	})
   161  
   162  	return err
   163  }
   164  
   165  // Reset is fake implementation
   166  func (o *LoadBalancerOp) Reset(ctx context.Context, zone string, id types.ID) error {
   167  	value, err := o.Read(ctx, zone, id)
   168  	if err != nil {
   169  		return err
   170  	}
   171  	if !value.InstanceStatus.IsUp() {
   172  		return newErrorConflict(o.key, id, "Reset is failed")
   173  	}
   174  
   175  	startPowerOn(o.key, zone, func() (interface{}, error) {
   176  		return o.Read(context.Background(), zone, id)
   177  	})
   178  
   179  	return nil
   180  }
   181  
   182  // MonitorInterface is fake implementation
   183  func (o *LoadBalancerOp) MonitorInterface(ctx context.Context, zone string, id types.ID, condition *iaas.MonitorCondition) (*iaas.InterfaceActivity, error) {
   184  	_, err := o.Read(ctx, zone, id)
   185  	if err != nil {
   186  		return nil, err
   187  	}
   188  
   189  	now := time.Now().Truncate(time.Second)
   190  	m := now.Minute() % 5
   191  	if m != 0 {
   192  		now.Add(time.Duration(m) * time.Minute)
   193  	}
   194  
   195  	res := &iaas.InterfaceActivity{}
   196  	for i := 0; i < 5; i++ {
   197  		res.Values = append(res.Values, &iaas.MonitorInterfaceValue{
   198  			Time:    now.Add(time.Duration(i*-5) * time.Minute),
   199  			Send:    float64(random(1000)),
   200  			Receive: float64(random(1000)),
   201  		})
   202  	}
   203  
   204  	return res, nil
   205  }
   206  
   207  // Status is fake implementation
   208  func (o *LoadBalancerOp) Status(ctx context.Context, zone string, id types.ID) (*iaas.LoadBalancerStatusResult, error) {
   209  	value, err := o.Read(ctx, zone, id)
   210  	if err != nil {
   211  		return nil, err
   212  	}
   213  
   214  	var results []*iaas.LoadBalancerStatus
   215  	for _, vip := range value.VirtualIPAddresses {
   216  		status := &iaas.LoadBalancerStatus{
   217  			VirtualIPAddress: vip.VirtualIPAddress,
   218  			Port:             vip.Port,
   219  			CPS:              types.StringNumber(random(100)),
   220  		}
   221  		var servers []*iaas.LoadBalancerServerStatus
   222  		for _, server := range vip.Servers {
   223  			servers = append(servers, &iaas.LoadBalancerServerStatus{
   224  				ActiveConn: types.StringNumber(random(10)),
   225  				Status:     types.ServerInstanceStatuses.Up,
   226  				IPAddress:  server.IPAddress,
   227  				Port:       server.Port,
   228  				CPS:        types.StringNumber(random(100)),
   229  			})
   230  		}
   231  		status.Servers = servers
   232  
   233  		results = append(results, status)
   234  	}
   235  
   236  	return &iaas.LoadBalancerStatusResult{
   237  		Status: results,
   238  	}, nil
   239  }
   240  
   241  // MonitorCPU is fake implementation
   242  func (o *LoadBalancerOp) MonitorCPU(ctx context.Context, zone string, id types.ID, condition *iaas.MonitorCondition) (*iaas.CPUTimeActivity, error) {
   243  	_, err := o.Read(ctx, zone, id)
   244  	if err != nil {
   245  		return nil, err
   246  	}
   247  
   248  	now := time.Now().Truncate(time.Second)
   249  	m := now.Minute() % 5
   250  	if m != 0 {
   251  		now.Add(time.Duration(m) * time.Minute)
   252  	}
   253  
   254  	res := &iaas.CPUTimeActivity{}
   255  	for i := 0; i < 5; i++ {
   256  		res.Values = append(res.Values, &iaas.MonitorCPUTimeValue{
   257  			Time:    now.Add(time.Duration(i*-5) * time.Minute),
   258  			CPUTime: float64(random(1000)),
   259  		})
   260  	}
   261  
   262  	return res, nil
   263  }