登录
首页 >  Golang >  Go问答

go test 导致没有这样的文件或目录

来源:stackoverflow

时间:2024-02-21 13:36:25 203浏览 收藏

知识点掌握了,还需要不断练习才能熟练运用。下面golang学习网给大家带来一个Golang开发实战,手把手教大家学习《go test 导致没有这样的文件或目录》,在实现功能的过程中也带大家重新温习相关知识点,温故而知新,回头看看说不定又有不一样的感悟!

问题内容

我正在 go 中创建 restfull api 并使用 jwt 保护我的应用程序。我正在使用 ecdsa 算法,因此我有 privatepublic 密钥对。为了创建 jwt 令牌,我必须读取它们。

首先这是我的项目结构:

.
├── dockerfile
├── makefile
├── config
│   └── config.go
├── config.json
├── data
│   ├── init.sql
│   ├── keys
│   │   ├── 256
│   │   │   ├── keys-256.md
│   │   │   ├── private-key.pem
│   │   │   └── public-key.pem
│   │   └── 512
│   │       ├── keys-512.md
│   │       ├── private-key.pem
│   │       └── public-key.pem
│   └── ....
├── go.mod
├── go.sum
├── handler
│   ├── auth.go
│   ├── auth_test.go
│   ├── healthcheck.go
│   └── healthcheck_test.go
│   
├── main.go
└── security
    └── token
        ├── generator.go
        └── parser.go

这是我读取私钥文件的源文件,您可以看到我正在 go 中使用 init 函数,因此我将读取一次密钥文件并在每次需要时使用它。

生成器.go

package security

import (
    "crypto/ecdsa"
    "fmt"
    "io/ioutil"
    "log"
    "net/http"
    "strconv"
    "time"

    "github.com/golang-jwt/jwt"
    // ...
)

var privatekeypath = "data/keys/512/private-key.pem"
var privatekey *ecdsa.privatekey

func init() {
    printworkingdirectory()
    privatekey = getecdsaprivatekey(readprivatekeyfile())
}



func getecdsaprivatekey(data []byte) *ecdsa.privatekey {
        ecdsakey, err := jwt.parseecprivatekeyfrompem(data);
    if  err != nil {
        log.fatalf("unable to parse ecdsa private key: %v", err)
    }
    return ecdsakey
}

func readprivatekeyfile() []byte {
    data, err := ioutil.readfile(privatekeypath)
    if err != nil {
        log.fatalf("can not read private key file: %v", err)
    }
    return data;
}
func printworkingdirectory() {
    mydir, err := os.getwd()
    if err != nil {
        fmt.println(err)
    }
    fmt.println("working directory: ", mydir)
}
//...

密钥路径相对于项目根目录 var privatekeypath = "data/keys/512/private-key.pem"

当我在根目录中运行 go run . 时,一切正常。

当我运行 go test ./... golang 会创建一个临时目录并在其中运行我的测试,这基本上会导致问题。 这是 go 测试的结果./...:

✗ go test -v ./...

Working directory is:  /var/folders/wk/ncyvbtdj3w57cr5j1v46x7dr39dz_l/T/go-build4211274972/b150
Initing db manger
2021/10/28 19:13:47 Can not read private key file: open data/keys/512/private-key.pem: no such file or directory
FAIL    mydomain/myprojectname/handler   1.274s

实际上我是一名 java 开发人员,而且是 go 新手

简单来说,在 java 中,我们有 classpath,它可以拯救世界。

我不想使用 absolute path 因为我有 dockerfile,如果我在本地计算机中使用绝对路径,它会在 docker 容器中伤害我。

我的问题是:

如何使用与 go rungo test 命令一起使用的相对路径。


正确答案


您面临的问题是因为当您运行 go run 时,或者当您运行构建的应用程序时,工作目录是从您的环境继承的。但是当测试包时,工作目录始终是包目录。

一个快速解决方案是在 security 目录中保存 data 目录的副本作为测试装置,这也允许您使用特定密钥进行测试。

更好的解决方案是考虑如何在生产中加载密钥。 security 包中的 init() 函数非常不灵活,因为:

  1. 在生产中,您的密钥必须位于仅相对于工作目录的特定位置。
  2. 您无法影响测试中 init() 函数的行为,因为 init() 始终在测试开始之前运行。

我的建议是,不要使用 init(),而是在实例化 main 时将文本密钥或密钥路径传递到 security 包中的类中。这样,您的密钥可以在生产过程中位于任何位置,并且可以引导您的测试使用源树中相对于该包目录的密钥。

本篇关于《go test 导致没有这样的文件或目录》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于Golang的相关知识,请关注golang学习网公众号!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>