热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

awslambda测试_在Go中对AWSLambda进行单元测试

awslambda测试当我开始在Go和AWSLambda中工作时,我面临的困难之一是单元测试。我对什么是单元测试有一个不错的想法,并且知道如何在Ruby

aws lambda 测试

当我开始在Go和AWS Lambda中工作时,我面临的困难之一是单元测试。 我对什么是单元测试有一个不错的想法,并且知道如何在Ruby中进行测试,但是在Go中,我不知道是什么原因,因为我是一个初学者。

学习围棋本身就是一个挑战。 主要是因为Go不是一种OOP语言。 我开始在Go上阅读文章,并在YouTube上观看了许多视频系列。 几天后,我逐渐好起来,并且能够理解事物。 但是我想学习如何进行单元测试,不幸的是,没有很多好的博客来说明如何使用Go进行AWS单元测试。 因此,此博客旨在解释如何使用Go正确地对AWS服务进行单元测试。

在博客中,我将演示如何对在Go中使用EMR服务的Lambda进行单元测试。 代码很简单,给出了集群ID,我必须获取集群状态。

永远记住,如果要在Go中进行单元测试,则必须使用接口,并尽可能避免使用具体的API或函数。 所以对于aws-sdk-go ,我们有一些接口,例如dynamodb
dynamodbiface您可以看到aws-sdk-go来查看服务的iface名称是什么。 通常,其service-nameiface.

现在开始编码

首先,我将创建将集群ID作为输入并将emr接口作为API的结构

// ClusterInput represent input which will be given to the lambda
type ClusterInput struct {ClusterID string `json:"clusterID"`
}// awsService represents emr interface
type awsService struct {emr emriface.EMRAPI
}

接下来,我将创建一个函数,其功能是创建一个新的AWS会话并创建一个新的emr服务

// newAWSService returns a new instance of emr
func newAWSService () * awsService {awsConfig := &aws.Config{Region: aws.String( "us-west-2" )}sess, err := session.NewSession(awsConfig)if err != nil {log.Errorf( "error while creating AWS session - %s" , err.Error())}return &awsService{emr: emr.New(sess),}
}

现在,来了肉的部分。 我将进行输入验证,并准备输入DescribeCluster emr API方法。 休息就很简单。

// getClusterStatus returns current cluster status along with an error
func (svc *awsService) getClusterStatus (input ClusterInput) ( string , error) {clusterID := input.ClusterIDif clusterID == "" {return "" , errors.New( "clusterID is empty" )}describeClusterInput := &emr.DescribeClusterInput{ClusterId: aws.String(clusterID),}clusterDetails, err := svc.emr.DescribeCluster(describeClusterInput)if err != nil {log.Errorf( "DescribeCluster error - %s" , err)return "" , err}if clusterDetails == nil {log.Errorf( "clusterID does not exist" )return "" , errors.New( "clusterID does not exist" )}clusterStatus := *clusterDetails.Cluster.Status.Statereturn string (clusterStatus), nil
}

要了解的重点是我如何在DescribeClusterInput上使用&emr 。 如果您想使用任何其他AWS服务,那么您应该做类似的事情。

现在开始测试

对于测试,我将使用Stretcher / Testify,因为它提供了模拟和断言功能。 尤其是模拟非常重要。 当您编写单元测试时,它不应该调用真实服务是至关重要的。 它应该始终调用模拟服务。

首先,我将创建模拟emr并创建DescribeCluster方法的模拟实现。 之后,我将创建setup方法

// mockEMR represents mock implementation of AWS EMR service
type mockEMR struct {emriface.EMRAPImock.Mock
}// DescribeCluster is a mocked method which return the cluster status
func (m *mockEMR) DescribeCluster (input *emr.DescribeClusterInput) (*emr.DescribeClusterOutput, error) {args := m.Called(input)return args.Get( 0 ).(*emr.DescribeClusterOutput), args.Error( 1 )
}func setup () (*mockEMR, *awsService) {mockEMRClient := new (mockEMR)mockEMR := &awsService{emr: mockEMRClient,}return mockEMRClient, mockEMR
}

现在,该编写表驱动测试并调用原始函数了。 一旦调用了原始函数,我就可以断言预期结果是否与实际结果匹配。

mockEMRClient, mockEMR := setup()mockDescribeClusterInput := &emr.DescribeClusterInput{ClusterId: aws.String(testCase.clusterID),
}mockDescribeClusterOutput := &emr.DescribeClusterOutput{Cluster: &emr.Cluster{Status: &emr.ClusterStatus{State: aws.String(testCase.expectedClusterStatus),},},
}mockEMRClient.On("DescribeCluster" , mockDescribeClusterInput).Return(mockDescribeClusterOutput, testCase.emrError)
res, err := mockEMR.getClusterStatus(testCase.expectedInput)assert.Equal(t, testCase.expectedClusterStatus, res, testCase.message)
assert.IsType(t, testCase.expectedError, err, testCase.message)

而已! 我希望阅读此博客后,您可以了解Go中的一点单元测试AWS Lambda。

检出aws-unit-test-golang以获取完整代码

翻译自: https://hackernoon.com/unit-test-aws-lambda-in-go-h85l3ymz

aws lambda 测试



推荐阅读
  • Imtryingtofigureoutawaytogeneratetorrentfilesfromabucket,usingtheAWSSDKforGo.我正 ... [详细]
  • VScode格式化文档换行或不换行的设置方法
    本文介绍了在VScode中设置格式化文档换行或不换行的方法,包括使用插件和修改settings.json文件的内容。详细步骤为:找到settings.json文件,将其中的代码替换为指定的代码。 ... [详细]
  • 本文介绍了Redis的基础数据结构string的应用场景,并以面试的形式进行问答讲解,帮助读者更好地理解和应用Redis。同时,描述了一位面试者的心理状态和面试官的行为。 ... [详细]
  • 本文介绍了如何在给定的有序字符序列中插入新字符,并保持序列的有序性。通过示例代码演示了插入过程,以及插入后的字符序列。 ... [详细]
  • 个人学习使用:谨慎参考1Client类importcom.thoughtworks.gauge.Step;importcom.thoughtworks.gauge.T ... [详细]
  • HDFS2.x新特性
    一、集群间数据拷贝scp实现两个远程主机之间的文件复制scp-rhello.txtroothadoop103:useratguiguhello.txt推pushscp-rr ... [详细]
  • Oracle seg,V$TEMPSEG_USAGE与Oracle排序的关系及使用方法
    本文介绍了Oracle seg,V$TEMPSEG_USAGE与Oracle排序之间的关系,V$TEMPSEG_USAGE是V_$SORT_USAGE的同义词,通过查询dba_objects和dba_synonyms视图可以了解到它们的详细信息。同时,还探讨了V$TEMPSEG_USAGE的使用方法。 ... [详细]
  • 本文讨论了在openwrt-17.01版本中,mt7628设备上初始化启动时eth0的mac地址总是随机生成的问题。每次随机生成的eth0的mac地址都会写到/sys/class/net/eth0/address目录下,而openwrt-17.01原版的SDK会根据随机生成的eth0的mac地址再生成eth0.1、eth0.2等,生成后的mac地址会保存在/etc/config/network下。 ... [详细]
  • 本文介绍了如何清除Eclipse中SVN用户的设置。首先需要查看使用的SVN接口,然后根据接口类型找到相应的目录并删除相关文件。最后使用SVN更新或提交来应用更改。 ... [详细]
  • Spring常用注解(绝对经典),全靠这份Java知识点PDF大全
    本文介绍了Spring常用注解和注入bean的注解,包括@Bean、@Autowired、@Inject等,同时提供了一个Java知识点PDF大全的资源链接。其中详细介绍了ColorFactoryBean的使用,以及@Autowired和@Inject的区别和用法。此外,还提到了@Required属性的配置和使用。 ... [详细]
  • 本文介绍了在iOS开发中使用UITextField实现字符限制的方法,包括利用代理方法和使用BNTextField-Limit库的实现策略。通过这些方法,开发者可以方便地限制UITextField的字符个数和输入规则。 ... [详细]
  • 本文介绍了一个适用于PHP应用快速接入TRX和TRC20数字资产的开发包,该开发包支持使用自有Tron区块链节点的应用场景,也支持基于Tron官方公共API服务的轻量级部署场景。提供的功能包括生成地址、验证地址、查询余额、交易转账、查询最新区块和查询交易信息等。详细信息可参考tron-php的Github地址:https://github.com/Fenguoz/tron-php。 ... [详细]
  • GreenDAO快速入门
    前言之前在自己做项目的时候,用到了GreenDAO数据库,其实对于数据库辅助工具库从OrmLite,到litePal再到GreenDAO,总是在不停的切换,但是没有真正去了解他们的 ... [详细]
  • 本文介绍了Oracle数据库中tnsnames.ora文件的作用和配置方法。tnsnames.ora文件在数据库启动过程中会被读取,用于解析LOCAL_LISTENER,并且与侦听无关。文章还提供了配置LOCAL_LISTENER和1522端口的示例,并展示了listener.ora文件的内容。 ... [详细]
  • 本文介绍了在MFC下利用C++和MFC的特性动态创建窗口的方法,包括继承现有的MFC类并加以改造、插入工具栏和状态栏对象的声明等。同时还提到了窗口销毁的处理方法。本文详细介绍了实现方法并给出了相关注意事项。 ... [详细]
author-avatar
腾讯财经321
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有