move gotd fork into repo. (#111)

- update to latest telegram layer
- remove some references to fields in tg.Entities that don't exist in
the schema
- originally added here:
https://github.com/beeper/td/commit/820929062a2ba0104397bc01235ab58a9cff780e
  - referenced here
-
https://github.com/mautrix/telegramgo/commit/124f0967ed195b5a380c9bd02e170ada9710dde3
-
https://github.com/mautrix/telegramgo/commit/4205047aab2e0639217148b5d125bfaab668bd8e
This commit is contained in:
Adam Van Ymeren
2025-06-27 20:03:37 -07:00
committed by GitHub
parent 0952df0244
commit 7a04f298d2
19264 changed files with 1539697 additions and 84 deletions
+115
View File
@@ -0,0 +1,115 @@
package tgerr_test
import (
"testing"
"github.com/go-faster/errors"
"github.com/stretchr/testify/require"
"go.mau.fi/mautrix-telegram/pkg/gotd/testutil"
"go.mau.fi/mautrix-telegram/pkg/gotd/tg"
"go.mau.fi/mautrix-telegram/pkg/gotd/tgerr"
)
func TestError(t *testing.T) {
t.Run("FLOOD_WAIT_0", func(t *testing.T) {
require.Equal(t, "rpc error code 420: FLOOD_WAIT (0)", tgerr.New(420, "FLOOD_WAIT_0").Error())
})
t.Run("FLOOD_WAIT", func(t *testing.T) {
require.Equal(t, "rpc error code 420: FLOOD_WAIT", tgerr.New(420, "FLOOD_WAIT").Error())
})
}
func TestErrorParse(t *testing.T) {
t.Run("FLOOD_WAIT", func(t *testing.T) {
require.Equal(t, &tgerr.Error{
Code: 420,
Message: "FLOOD_WAIT_359",
Type: "FLOOD_WAIT",
Argument: 359,
}, tgerr.New(420, "FLOOD_WAIT_359"))
})
t.Run("FLOOD_WAIT_0", func(t *testing.T) {
require.Equal(t, &tgerr.Error{
Code: 420,
Message: "FLOOD_WAIT_0",
Type: "FLOOD_WAIT",
Argument: 0,
}, tgerr.New(420, "FLOOD_WAIT_0"))
})
t.Run("Middle", func(t *testing.T) {
require.Equal(t, &tgerr.Error{
Code: 169,
Message: "GO_1337_METERS_AWAY",
Type: "GO_METERS_AWAY",
Argument: 1337,
}, tgerr.New(169, "GO_1337_METERS_AWAY"))
})
}
func TestHelpers(t *testing.T) {
err := func() error {
return tgerr.New(169, "GO_1337_METERS_AWAY")
}()
t.Run("Type", func(t *testing.T) {
require.True(t, tgerr.Is(err, "GO_METERS_AWAY"))
require.True(t, tgerr.Is(err, "FOO", "GO_METERS_AWAY"))
require.False(t, tgerr.Is(err, "NOPE"))
t.Run("AsType", func(t *testing.T) {
{
rpcErr, ok := tgerr.AsType(err, "NOPE")
require.False(t, ok)
require.Nil(t, rpcErr)
}
{
rpcErr, ok := tgerr.AsType(err, "GO_METERS_AWAY")
require.True(t, ok)
require.NotNil(t, rpcErr)
}
})
})
t.Run("Code", func(t *testing.T) {
require.True(t, tgerr.IsCode(err, 169))
require.True(t, tgerr.IsCode(err, 1, 169))
require.False(t, tgerr.IsCode(err, 168))
})
t.Run("Generated", func(t *testing.T) {
// Ensure that code generation works for errors.
err := func() error {
rpcErr := &tgerr.Error{
Type: tg.ErrAccessTokenExpired,
}
return errors.Wrap(rpcErr, "perform operation")
}()
require.True(t, tgerr.Is(err, tg.ErrAccessTokenExpired))
require.True(t, tg.IsAccessTokenExpired(err))
})
t.Run("ErrorType", func(t *testing.T) {
tests := []struct {
name string
value error
}{
{"Nil", nil},
{"WrongType", testutil.TestError()},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
a := require.New(t)
e := tt.value
_, ok := tgerr.As(e)
a.False(ok)
_, ok = tgerr.AsType(e, "")
a.False(ok)
_, ok = tgerr.AsFloodWait(e)
a.False(ok)
a.False(tgerr.Is(e, ""))
a.False(tgerr.IsCode(e, 0))
})
}
})
}