Skip to content

Commit

Permalink
fix(e2e): self-hosted Telegram server (#757)
Browse files Browse the repository at this point in the history
  • Loading branch information
iyear authored Oct 25, 2024
1 parent 226b09e commit 659102c
Show file tree
Hide file tree
Showing 11 changed files with 211 additions and 45 deletions.
27 changes: 22 additions & 5 deletions .github/workflows/master.yml
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,7 @@ jobs:
with:
version: v1.54
working-directory: ${{ matrix.directory }}
build-and-test:
unit-test:
runs-on: ubuntu-latest
steps:
- name: Checkout
Expand All @@ -47,13 +47,30 @@ jobs:
with:
go-version-file: go.mod
cache: true
- name: Install Ginkgo
run: go install github.com/onsi/ginkgo/v2/ginkgo
- name: Build
run: go build
- name: Unit Test
run: go test -v $(go list ./... | grep -v /test) # skip e2e test
e2e-test:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Setup Golang env
uses: actions/setup-go@v5
with:
go-version-file: go.mod
cache: true
- name: Install Ginkgo
run: go install github.com/onsi/ginkgo/v2/ginkgo
- name: Setup Teamgram Env
run: |
git clone https://github.com/iyear/teamgram-server.git
cd teamgram-server
git checkout 3cc9864cda9a4eb45b61542494dfe517bf643372
sudo docker compose -f ./docker-compose-env.yaml up -d --quiet-pull
sudo docker compose up -d --quiet-pull
- name: Build
run: go build
- name: E2E Test
run: ginkgo -v -r ./test
env:
TDL_TEST: ${{ secrets.TEST_SESSION }}
1 change: 0 additions & 1 deletion app/login/code.go
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,6 @@ func Code(ctx context.Context) error {
Proxy: viper.GetString(consts.FlagProxy),
NTP: viper.GetString(consts.FlagNTP),
ReconnectTimeout: viper.GetDuration(consts.FlagReconnectTimeout),
Test: viper.GetString(consts.FlagTest),
UpdateHandler: nil,
}, true)
if err != nil {
Expand Down
1 change: 0 additions & 1 deletion app/login/qr.go
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,6 @@ func QR(ctx context.Context) error {
Proxy: viper.GetString(consts.FlagProxy),
NTP: viper.GetString(consts.FlagNTP),
ReconnectTimeout: viper.GetDuration(consts.FlagReconnectTimeout),
Test: viper.GetString(consts.FlagTest),
UpdateHandler: d,
}, true)
if err != nil {
Expand Down
4 changes: 0 additions & 4 deletions cmd/root.go
Original file line number Diff line number Diff line change
Expand Up @@ -133,9 +133,6 @@ func New() *cobra.Command {
cmd.PersistentFlags().String(consts.FlagNTP, "", "ntp server host, if not set, use system time")
cmd.PersistentFlags().Duration(consts.FlagReconnectTimeout, 5*time.Minute, "Telegram client reconnection backoff timeout, infinite if set to 0") // #158

cmd.PersistentFlags().String(consts.FlagTest, "", "use test Telegram client, only for developer")
_ = cmd.PersistentFlags().MarkHidden(consts.FlagTest)

// completion
_ = cmd.RegisterFlagCompletionFunc(consts.FlagNamespace, func(cmd *cobra.Command, args []string, toComplete string) ([]string, cobra.ShellCompDirective) {
engine := kv.From(cmd.Context())
Expand Down Expand Up @@ -183,7 +180,6 @@ func tRun(ctx context.Context, f func(ctx context.Context, c *telegram.Client, k
Proxy: viper.GetString(consts.FlagProxy),
NTP: viper.GetString(consts.FlagNTP),
ReconnectTimeout: viper.GetDuration(consts.FlagReconnectTimeout),
Test: viper.GetString(consts.FlagTest),
UpdateHandler: nil,
}

Expand Down
13 changes: 13 additions & 0 deletions core/dcpool/dcpool.go
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,13 @@ import (
"github.com/iyear/tdl/core/middlewares/takeout"
)

var testMode = false

// EnableTestMode enables test mode, which disables takeout and pooling and directly returns original client.
func EnableTestMode() {
testMode = true
}

type Pool interface {
Client(ctx context.Context, dc int) *tg.Client
Takeout(ctx context.Context, dc int) *tg.Client
Expand Down Expand Up @@ -55,6 +62,12 @@ func (p *pool) Client(ctx context.Context, dc int) *tg.Client {
}

func (p *pool) invoker(ctx context.Context, dc int) tg.Invoker {
// self-hosted Telegram server can't properly handle pooling connections,
// so directly return original client
if testMode {
return p.api
}

if i, ok := p.invokers[dc]; ok {
return i
}
Expand Down
27 changes: 11 additions & 16 deletions core/tclient/tclient.go
Original file line number Diff line number Diff line change
Expand Up @@ -9,13 +9,11 @@ import (
"github.com/go-faster/errors"
"github.com/gotd/contrib/clock"
"github.com/gotd/contrib/middleware/floodwait"
"github.com/gotd/contrib/middleware/ratelimit"
tdclock "github.com/gotd/td/clock"
"github.com/gotd/td/session"
"github.com/gotd/td/exchange"
"github.com/gotd/td/telegram"
"github.com/gotd/td/telegram/dcs"
"golang.org/x/net/proxy"
"golang.org/x/time/rate"

"github.com/iyear/tdl/core/logctx"
"github.com/iyear/tdl/core/middlewares/recovery"
Expand All @@ -24,6 +22,13 @@ import (
"github.com/iyear/tdl/core/util/tutil"
)

// dc values can be overridden globally
var (
DCList dcs.List
DC int
PublicKeys []exchange.PublicKey
)

type Options struct {
AppID int
AppHash string
Expand All @@ -32,7 +37,6 @@ type Options struct {
Proxy string
NTP string
ReconnectTimeout time.Duration
Test string
UpdateHandler telegram.UpdateHandler
}

Expand Down Expand Up @@ -66,6 +70,9 @@ func New(ctx context.Context, o Options) (*telegram.Client, error) {
ReconnectionBackoff: func() backoff.BackOff {
return newBackoff(o.ReconnectTimeout)
},
DC: DC,
DCList: DCList,
PublicKeys: PublicKeys,
UpdateHandler: o.UpdateHandler,
Device: tutil.Device,
SessionStorage: o.Session,
Expand All @@ -77,18 +84,6 @@ func New(ctx context.Context, o Options) (*telegram.Client, error) {
Logger: logctx.From(ctx).Named("td"),
}

// test account session
if o.Test != "" {
storage := &session.StorageMemory{}
if err := storage.StoreSession(ctx, []byte(o.Test)); err != nil {
return nil, errors.Wrap(err, "store test session")
}
opts.SessionStorage = storage // hook original session storage

// add rate limit to avoid frequent flood wait
opts.Middlewares = append(opts.Middlewares, ratelimit.New(rate.Every(100*time.Millisecond), 5))
}

return telegram.NewClient(o.AppID, o.AppHash, opts), nil
}

Expand Down
1 change: 0 additions & 1 deletion pkg/consts/flag.go
Original file line number Diff line number Diff line change
Expand Up @@ -13,5 +13,4 @@ const (
FlagNTP = "ntp"
FlagReconnectTimeout = "reconnect-timeout"
FlagDlTemplate = "template"
FlagTest = "test"
)
2 changes: 0 additions & 2 deletions pkg/tclient/tclient.go
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,6 @@ type Options struct {
Proxy string
NTP string
ReconnectTimeout time.Duration
Test string
UpdateHandler telegram.UpdateHandler
}

Expand All @@ -40,7 +39,6 @@ func New(ctx context.Context, o Options, login bool, middlewares ...telegram.Mid
Proxy: o.Proxy,
NTP: o.NTP,
ReconnectTimeout: o.ReconnectTimeout,
Test: o.Test,
UpdateHandler: o.UpdateHandler,
})
}
31 changes: 16 additions & 15 deletions test/suite_test.go
Original file line number Diff line number Diff line change
@@ -1,19 +1,20 @@
package test

import (
"context"
_ "embed"
"fmt"
"io"
"log"
"math/rand"
"os"
"path/filepath"
"strconv"
"testing"
"time"

"github.com/fatih/color"
"github.com/spf13/cobra"

tcmd "github.com/iyear/tdl/cmd"
"github.com/iyear/tdl/test/testserver"

. "github.com/onsi/ginkgo/v2"
. "github.com/onsi/gomega"
Expand All @@ -25,25 +26,23 @@ func TestCommand(t *testing.T) {
}

var (
cmd *cobra.Command
args []string
output string
storage string
cmd *cobra.Command
args []string
output string
testAccount string
sessionFile string
)

var _ = BeforeSuite(func() {
// used to avoid "open db: timeout" conflict
storage = fmt.Sprintf("type=file,path=%s",
filepath.Join(os.TempDir(), "tdl", strconv.FormatInt(time.Now().UnixNano(), 10)))
var _ = BeforeSuite(func(ctx context.Context) {
var err error
testAccount, sessionFile, err = testserver.Setup(ctx, rand.NewSource(GinkgoRandomSeed()))
Expect(err).To(Succeed())

log.SetOutput(GinkgoWriter)
})

var _ = BeforeEach(func() {
cmd = tcmd.New()

// wait before each test to avoid rate limit
time.Sleep(10 * time.Second)
})

func exec(cmd *cobra.Command, args []string, success bool) {
Expand All @@ -54,7 +53,9 @@ func exec(cmd *cobra.Command, args []string, success bool) {

log.Printf("args: %s\n", args)
cmd.SetArgs(append([]string{
"--storage", storage,
"-s", "131072", // self-hosted Telegram server don't support 1MiB
"-n", testAccount,
"--storage", fmt.Sprintf("type=file,path=%s", sessionFile),
}, args...))
if err = cmd.Execute(); success {
Expect(err).To(Succeed())
Expand Down
8 changes: 8 additions & 0 deletions test/testserver/public_key.pem
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
-----BEGIN RSA PUBLIC KEY-----
MIIBCgKCAQEAvKLEOWTzt9Hn3/9Kdp/RdHcEhzmd8xXeLSpHIIzaXTLJDw8BhJy1
jR/iqeG8Je5yrtVabqMSkA6ltIpgylH///FojMsX1BHu4EPYOXQgB0qOi6kr08iX
ZIH9/iOPQOWDsL+Lt8gDG0xBy+sPe/2ZHdzKMjX6O9B4sOsxjFrk5qDoWDrioJor
AJ7eFAfPpOBf2w73ohXudSrJE0lbQ8pCWNpMY8cB9i8r+WBitcvouLDAvmtnTX7a
khoDzmKgpJBYliAY4qA73v7u5UIepE8QgV0jCOhxJCPubP8dg+/PlLLVKyxU5Cdi
QtZj2EMy4s9xlNKzX8XezE0MHEa6bQpnFwIDAQAB
-----END RSA PUBLIC KEY-----
Loading

0 comments on commit 659102c

Please sign in to comment.