2020-08-18 16:06:35 +00:00
|
|
|
package signature
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
|
2023-03-07 10:38:56 +00:00
|
|
|
"git.frostfs.info/TrueCloudLab/frostfs-api-go/v2/accounting"
|
|
|
|
"git.frostfs.info/TrueCloudLab/frostfs-api-go/v2/session"
|
|
|
|
crypto "git.frostfs.info/TrueCloudLab/frostfs-crypto"
|
2020-08-18 16:06:35 +00:00
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestBalanceResponse(t *testing.T) {
|
|
|
|
dec := new(accounting.Decimal)
|
|
|
|
dec.SetValue(100)
|
|
|
|
|
|
|
|
body := new(accounting.BalanceResponseBody)
|
|
|
|
body.SetBalance(dec)
|
|
|
|
|
2020-08-20 10:41:55 +00:00
|
|
|
meta := new(session.ResponseMetaHeader)
|
2020-08-18 16:06:35 +00:00
|
|
|
meta.SetTTL(1)
|
|
|
|
|
|
|
|
req := new(accounting.BalanceResponse)
|
|
|
|
req.SetBody(body)
|
|
|
|
req.SetMetaHeader(meta)
|
|
|
|
|
|
|
|
// verify unsigned request
|
|
|
|
require.Error(t, VerifyServiceMessage(req))
|
|
|
|
|
|
|
|
key, err := crypto.LoadPrivateKey("Kwk6k2eC3L3QuPvD8aiaNyoSXgQ2YL1bwS5CP1oKoA9waeAze97s")
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
// sign request
|
|
|
|
require.NoError(t, SignServiceMessage(key, req))
|
|
|
|
|
|
|
|
// verification must pass
|
|
|
|
require.NoError(t, VerifyServiceMessage(req))
|
|
|
|
|
|
|
|
// add level to meta header matryoshka
|
2020-08-20 10:41:55 +00:00
|
|
|
meta = new(session.ResponseMetaHeader)
|
2020-08-18 16:06:35 +00:00
|
|
|
meta.SetOrigin(req.GetMetaHeader())
|
|
|
|
req.SetMetaHeader(meta)
|
|
|
|
|
|
|
|
// sign request
|
|
|
|
require.NoError(t, SignServiceMessage(key, req))
|
|
|
|
|
|
|
|
// verification must pass
|
|
|
|
require.NoError(t, VerifyServiceMessage(req))
|
|
|
|
|
|
|
|
// corrupt body
|
|
|
|
dec.SetValue(dec.GetValue() + 1)
|
|
|
|
|
|
|
|
// verification must fail
|
|
|
|
require.Error(t, VerifyServiceMessage(req))
|
|
|
|
|
|
|
|
// restore body
|
|
|
|
dec.SetValue(dec.GetValue() - 1)
|
|
|
|
|
|
|
|
// corrupt meta header
|
|
|
|
meta.SetTTL(meta.GetTTL() + 1)
|
|
|
|
|
|
|
|
// verification must fail
|
|
|
|
require.Error(t, VerifyServiceMessage(req))
|
|
|
|
|
|
|
|
// restore meta header
|
|
|
|
meta.SetTTL(meta.GetTTL() - 1)
|
|
|
|
|
|
|
|
// corrupt origin verification header
|
|
|
|
req.GetVerificationHeader().SetOrigin(nil)
|
|
|
|
|
|
|
|
// verification must fail
|
|
|
|
require.Error(t, VerifyServiceMessage(req))
|
|
|
|
}
|
2023-02-28 11:43:13 +00:00
|
|
|
|
|
|
|
func BenchmarkSignRequest(b *testing.B) {
|
|
|
|
key, _ := crypto.LoadPrivateKey("Kwk6k2eC3L3QuPvD8aiaNyoSXgQ2YL1bwS5CP1oKoA9waeAze97s")
|
|
|
|
|
|
|
|
b.ResetTimer()
|
|
|
|
b.ReportAllocs()
|
|
|
|
|
2024-09-04 12:44:59 +00:00
|
|
|
for range b.N {
|
2023-02-28 11:43:13 +00:00
|
|
|
b.StopTimer()
|
|
|
|
dec := new(accounting.Decimal)
|
|
|
|
dec.SetValue(100)
|
|
|
|
|
|
|
|
body := new(accounting.BalanceResponseBody)
|
|
|
|
body.SetBalance(dec)
|
|
|
|
|
|
|
|
meta := new(session.ResponseMetaHeader)
|
|
|
|
meta.SetTTL(1)
|
|
|
|
|
|
|
|
resp := new(accounting.BalanceResponse)
|
|
|
|
resp.SetBody(body)
|
|
|
|
resp.SetMetaHeader(meta)
|
|
|
|
|
|
|
|
b.StartTimer()
|
|
|
|
SignServiceMessage(key, resp)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func BenchmarkVerifyRequest(b *testing.B) {
|
|
|
|
key, _ := crypto.LoadPrivateKey("Kwk6k2eC3L3QuPvD8aiaNyoSXgQ2YL1bwS5CP1oKoA9waeAze97s")
|
|
|
|
|
|
|
|
b.ResetTimer()
|
|
|
|
b.ReportAllocs()
|
|
|
|
|
2024-09-04 12:44:59 +00:00
|
|
|
for range b.N {
|
2023-02-28 11:43:13 +00:00
|
|
|
b.StopTimer()
|
|
|
|
dec := new(accounting.Decimal)
|
|
|
|
dec.SetValue(100)
|
|
|
|
|
|
|
|
body := new(accounting.BalanceResponseBody)
|
|
|
|
body.SetBalance(dec)
|
|
|
|
|
|
|
|
meta := new(session.ResponseMetaHeader)
|
|
|
|
meta.SetTTL(1)
|
|
|
|
|
|
|
|
resp := new(accounting.BalanceResponse)
|
|
|
|
resp.SetBody(body)
|
|
|
|
resp.SetMetaHeader(meta)
|
|
|
|
SignServiceMessage(key, resp)
|
|
|
|
b.StartTimer()
|
|
|
|
|
|
|
|
VerifyServiceMessage(resp)
|
|
|
|
}
|
|
|
|
}
|