草庐IT

test_key

全部标签

database - 确保在多台机器上跨表生成唯一的 key

我想使用这个Go包https://github.com/bwmarrin/snowflake为我在Postgresql中的表生成主int64键。如果我的应用程序服务器至少在两台机器上运行,我该如何防止生成重复的key? 最佳答案 所以snowflake提供了63位整数存储在一个int64中。根据文档,您可以每毫秒为每个节点ID生成4096个唯一ID。让我们采用默认实现。即每毫秒4096*1023=40961023个ID,如果您在一秒钟内计算,您可以在多个节点上生成数十亿个唯一ID,并且很少会发生冲突。所以我认为如果您在服务器的env

go - 使用 golang 在 google-cloud 数据存储中仅检索具有 key 的特定属性

MyKind有3个实体:FirstName、FamilyName和Email。我只想检索与该实体关联的Key和FirstName。在SQL中像这样:SELECTId,FirstNamefromusers;在go-lang中,我尝试像这样获取Kind中的所有数据q:=datastore.NewQuery(dataKind)然后为了拿到key,我这样做了:键,错误:=q.GetAll(ctx,&users)我不想获取所有属性,而只想获取键和名字。我想知道是否有办法在单个数据存储区查询中执行此操作?正如我之前的问题中提到的,我是go-lang和数据存储的新手。请帮忙

json - 在 golang 中动态地从 JSON 中删除 key

我有一个可变的JSON架构(json.RawMessage),它可以具有任意格式。我不知道编译时的格式。在golang中,我想检查root-JSON对象中是否存在一个键,如果存在,则完全删除该键并反序列化。例如,如果“foo”存在,我需要将其删除{"foo":[1,2,3],"bar123":"baz"}->{"bar123":"baz"}{"foo":"test","bar123":"baz"}->{"bar123":"baz"}{"foo":{"bar":"bar2"},"bar123":"baz"}->{"bar123":"baz"}{"bar123":"baz"}->{"bar

go - 在 jwt-go 中解析 JWT Auth token 时, key 类型无效

我正在GoLangAPI中设置安全中间件,似乎所有设置都正确,但我收到错误“key类型无效”。我已确认我的签名算法是RS256并且中间件选项已配置@SigningMethod:jwt.SigningMethodRS256我有一个有效的token……中间件中的所有其他内容都通过了。中间件中此错误的入口点是jwt.ParseRSAPrivateKeyFromPEM方法。我已将错误隔离在github.com/dgrijalva/jwt-go/rsa.go行的Verify()中:62是抛出的ErrInvalidKeyType。到目前为止,所有参数看起来都可靠且合适(例如m|signingStr

go - 如何在 GoLang 的命令行上取消设置标志 Visited for Tests

我正在尝试运行每次使用不同参数多次调用同一函数的测试。这是一个接受不同命令行标志的应用程序。如果未提供命令行标志,则使用默认值。flagset=make(map[string]bool)flagset["flag1"]=falseflagset["flag2"]=falseflagset["flag3"]=falseflagset["flag4"]=falsefuncLoadCommandLineArguments(args[]string)error{err:=flag.CommandLine.Parse(args)/*Doerrorhandling*/flag.Visit(func

encryption - 在 Go 中使用 RSA 进行 key 交换的 AES 加密通信

我正在尝试在基于RubySinatra的网络后端和GoogleGo应用程序之间建立安全通信。Go应用程序包含公钥并最初打开连接。然后它使用其公钥加密随机生成的AES,并将其发送到Web后端。所有即将到来的(大容量)数据都将使用AESkey加密。这是一般可用的方法吗?Go代码如下所示aesRand:=make([]byte,32)rand.Read(aesRand)AESBlock,_=aes.NewCipher(aesRand)//EncryptAESkeywithRSAdata,err:=rsa.EncryptPKCS1v15(rand.Reader,PubKey,aesRand)现

unit-testing - 使用 aetest.NewContext 代替 endpoints.NewContext 以强一致性测试 go-endpoints

我有一个搜索方法:func(sa*SearchApi)Search(cendpoints.Context,r*SearchQuery)(*SearchResults,error){..}如您所见,它需要一个端点。上下文例如:ctx:=endpoints.NewContext(req1)但是对于aetest,我使用的是不同的上下文:otherCtx,err:=aetest.NewContext(&aetest.Options{"",true})特别是这个上下文有额外的强一致性选项-因为我正在设置数据所以我可以测试一个只读的api。我无法将otherCxt传递给我的Search方法,因为它

unit-testing - Golang Mocking - 类型冲突问题

我正在模拟一个DataStore及其获取/设置功能。我遇到的问题是:不能在EventHandler的参数中使用s(类型*MockStore)作为类型*datastore.Storage这是因为我的EventHandler函数需要传递一个*datastore.Storage作为参数类型。我想使用我创建的MockStore而不是真正的数据存储来测试(http测试)EvenHandler()。我正在使用golangtestify模拟包。一些代码示例typeMockStorestruct{mock.Mock}func(s*MockStore)Get()...funcEventHandler(w

unit-testing - App Engine 本地单元测试不同实例 [GO]

我在测试单独的方法时遇到问题,每个测试用例都在不同的实例和地址上运行。我正在寻找一种方法来设置API地址,以便在同一API服务器上执行测试。我假设此警告是问题的一部分。WARNING2015-11-0418:15:25,003devappserver2.py:779]DEFAULT_VERSION_HOSTNAMEwillnotbesetcorrectlywith--port=0此命令将设置API服务器,但我不能为测试做同样的事情...dev_appserver.py.--api_port55555 最佳答案 使用aetest.Ne

unit-testing - 运行 Ginkgo 测试套件(在运行任何规范之前设置 BeforeSuite

我正在使用Ginkgo(和Gomega)包对Go(lang)RestAPI进行单元测试。我需要使用全局设置,这应该可以通过定义来实现var_=BeforeSuite(func(){...})然后每个规范(具体的_test.go)应该在这个全局设置之后运行。不幸的是我不能让这发生......我的套件文件名为handlers_suite_test.go我的第一个测试规范名称是cartContentsHandler_test.go.在我看来,Ginkgo按字母顺序运行测试文件,使得cartContentsHandler_test.go运行之前handlers_suite_test.go.我放