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
@@ -0,0 +1,90 @@
package hook
import (
"context"
"testing"
"github.com/go-faster/errors"
"github.com/stretchr/testify/assert"
"go.mau.fi/mautrix-telegram/pkg/gotd/telegram"
"go.mau.fi/mautrix-telegram/pkg/gotd/bin"
"go.mau.fi/mautrix-telegram/pkg/gotd/tg"
)
func TestUpdateHook_InvokeRaw(t *testing.T) {
t.Run("Success", func(t *testing.T) {
var invokerCalled, hookCalled bool
assert.NoError(t, UpdateHook(func(ctx context.Context, u tg.UpdatesClass) error {
assert.NotNil(t, u)
hookCalled = true
return nil
}).Handle(telegram.InvokeFunc(func(ctx context.Context, input bin.Encoder, output bin.Decoder) error {
invokerCalled = true
return nil
})).Invoke(context.TODO(), nil, &tg.UpdatesBox{
Updates: &tg.UpdateShortMessage{
ID: 100,
},
}))
assert.True(t, invokerCalled, "invoker should be called")
assert.True(t, hookCalled, "hook should be called")
})
t.Run("Error", func(t *testing.T) {
t.Run("Handler", func(t *testing.T) {
var invokerCalled, hookCalled bool
err := errors.New("failure")
assert.ErrorIs(t, UpdateHook(func(ctx context.Context, u tg.UpdatesClass) error {
assert.NotNil(t, u)
hookCalled = true
return nil
}).Handle(telegram.InvokeFunc(func(ctx context.Context, input bin.Encoder, output bin.Decoder) error {
invokerCalled = true
return err
})).Invoke(context.TODO(), nil, &tg.UpdatesBox{
Updates: &tg.UpdateShortMessage{
ID: 100,
},
}), err)
assert.True(t, invokerCalled, "invoker should be called")
assert.False(t, hookCalled, "hook should not be called")
})
t.Run("Hook", func(t *testing.T) {
var invokerCalled, hookCalled bool
err := errors.New("failure")
assert.ErrorIs(t, UpdateHook(func(ctx context.Context, u tg.UpdatesClass) error {
assert.NotNil(t, u)
hookCalled = true
return err
}).Handle(telegram.InvokeFunc(func(ctx context.Context, input bin.Encoder, output bin.Decoder) error {
invokerCalled = true
return nil
})).Invoke(context.TODO(), nil, &tg.UpdatesBox{
Updates: &tg.UpdateShortMessage{
ID: 100,
},
}), err)
assert.True(t, invokerCalled, "invoker should be called")
assert.True(t, hookCalled, "hook should be called")
})
})
t.Run("Not update", func(t *testing.T) {
var invokerCalled, hookCalled bool
assert.NoError(t, UpdateHook(func(ctx context.Context, u tg.UpdatesClass) error {
assert.NotNil(t, u)
hookCalled = true
return nil
}).Handle(telegram.InvokeFunc(func(ctx context.Context, input bin.Encoder, output bin.Decoder) error {
invokerCalled = true
return nil
})).Invoke(context.TODO(), nil, &tg.User{}))
assert.True(t, invokerCalled, "invoker should be called")
assert.False(t, hookCalled, "hook should not be called")
})
}