Skip to content

Commit

Permalink
Release v2021.12.06.1 (pingcap#1084)
Browse files Browse the repository at this point in the history
  • Loading branch information
shhdgit authored Dec 6, 2021
1 parent 80363df commit bcc43a0
Show file tree
Hide file tree
Showing 8 changed files with 156 additions and 22 deletions.
10 changes: 5 additions & 5 deletions pkg/apiserver/profiling/fetcher.go
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,6 @@ package profiling

import (
"fmt"
"net/http"
"time"

"go.uber.org/fx"
Expand Down Expand Up @@ -103,8 +102,9 @@ type pdFetcher struct {

func (f *pdFetcher) fetch(op *fetchOptions) ([]byte, error) {
baseURL := fmt.Sprintf("%s://%s:%d", f.statusAPIHTTPScheme, op.ip, op.port)
f.client.WithBeforeRequest(func(req *http.Request) {
req.Header.Add("PD-Allow-follower-handle", "true")
})
return f.client.WithTimeout(maxProfilingTimeout).WithBaseURL(baseURL).SendGetRequest(op.path)
return f.client.
WithTimeout(maxProfilingTimeout).
WithBaseURL(baseURL).
AddRequestHeader("PD-Allow-follower-handle", "true").
SendGetRequest(op.path)
}
27 changes: 19 additions & 8 deletions pkg/httpc/client.go
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,8 @@ const (

type Client struct {
http.Client
BeforeRequest func(req *http.Request)

header http.Header
}

func NewHTTPClient(lc fx.Lifecycle, config *config.Config) *Client {
Expand All @@ -63,14 +64,27 @@ func NewHTTPClient(lc fx.Lifecycle, config *config.Config) *Client {
}
}

// Clone is a temporary solution to the unexpected shared pointer field and race problem
// TODO: use latest `/util/client` for better api experience.
func (c *Client) Clone() *Client {
return &Client{
Client: c.Client,
header: c.header.Clone(),
}
}

func (c Client) WithTimeout(timeout time.Duration) *Client {
c.Timeout = timeout
return &c
}

func (c Client) WithBeforeRequest(callback func(req *http.Request)) *Client {
c.BeforeRequest = callback
return &c
func (c *Client) CloneAndAddRequestHeader(key, value string) *Client {
cc := c.Clone()
if cc.header == nil {
cc.header = http.Header{}
}
cc.header.Add(key, value)
return cc
}

// TODO: Replace using go-resty
Expand Down Expand Up @@ -101,10 +115,7 @@ func (c *Client) Send(
log.Warn("SendRequest failed", zap.String("uri", uri), zap.Error(err))
return nil, e
}

if c.BeforeRequest != nil {
c.BeforeRequest(req)
}
req.Header = c.header

resp, err := c.Do(req)
if err != nil {
Expand Down
67 changes: 67 additions & 0 deletions pkg/httpc/client_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,67 @@
// Copyright 2021 PingCAP, Inc. Licensed under Apache-2.0.

package httpc

import (
"context"
"net/http"
"net/http/httptest"
"testing"

"github.com/stretchr/testify/require"
"go.uber.org/fx/fxtest"

"github.com/pingcap/tidb-dashboard/pkg/config"
)

func newTestClient(t *testing.T) *Client {
lc := fxtest.NewLifecycle(t)
config := &config.Config{}
return NewHTTPClient(lc, config)
}

func Test_Clone(t *testing.T) {
c := newTestClient(t)
cc := c.Clone()

require.NotSame(t, c, cc)

require.Nil(t, c.header)
require.Nil(t, cc.header)
require.NotSame(t, c.header, cc.header)
}

func Test_CloneAndAddRequestHeader(t *testing.T) {
c := newTestClient(t)
cc := c.CloneAndAddRequestHeader("1", "11")

require.Nil(t, c.header)
require.Equal(t, "11", cc.header.Get("1"))

cc2 := cc.CloneAndAddRequestHeader("2", "22")
require.Equal(t, "11", cc.header.Get("1"))
require.Equal(t, "", cc.header.Get("2"))
require.Equal(t, "11", cc2.header.Get("1"))
require.Equal(t, "22", cc2.header.Get("2"))
}

func Test_Send_withHeader(t *testing.T) {
ts := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
_, _ = w.Write([]byte(r.Header.Get("1")))
}))
defer ts.Close()

c := newTestClient(t)
resp1, _ := c.Send(context.Background(), ts.URL, http.MethodGet, nil, nil, "")
d1, _ := resp1.Body()
require.Equal(t, "", string(d1))

cc := c.CloneAndAddRequestHeader("1", "11")
resp2, _ := cc.Send(context.Background(), ts.URL, http.MethodGet, nil, nil, "")
d2, _ := resp2.Body()
require.Equal(t, "11", string(d2))

resp3, _ := c.Send(context.Background(), ts.URL, http.MethodGet, nil, nil, "")
d3, _ := resp3.Body()
require.Equal(t, "", string(d3))
}
6 changes: 5 additions & 1 deletion pkg/keyvisual/storage/model.go
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,8 @@ import (
"encoding/gob"
"time"

"gorm.io/gorm"

"github.com/pingcap/tidb-dashboard/pkg/dbstore"
"github.com/pingcap/tidb-dashboard/pkg/keyvisual/matrix"
)
Expand Down Expand Up @@ -77,7 +79,9 @@ func CreateTableAxisModelIfNotExists(db *dbstore.DB) (bool, error) {
}

func ClearTableAxisModel(db *dbstore.DB) error {
return db.Delete(&AxisModel{}).Error
return db.Session(&gorm.Session{AllowGlobalUpdate: true}).
Delete(&AxisModel{}).
Error
}

func FindAxisModelsOrderByTime(db *dbstore.DB, layerNum uint8) ([]*AxisModel, error) {
Expand Down
10 changes: 5 additions & 5 deletions pkg/keyvisual/storage/model_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -74,7 +74,7 @@ func (t *testDbstoreSuite) TestClearTableAxisModel(c *C) {
if err != nil {
c.Fatalf("Count table AxisModel error: %v", err)
}
c.Assert(count, Equals, 1)
c.Assert(count, Equals, int64(1))

err = ClearTableAxisModel(t.db)
c.Assert(err, IsNil)
Expand All @@ -83,7 +83,7 @@ func (t *testDbstoreSuite) TestClearTableAxisModel(c *C) {
if err != nil {
c.Fatalf("Count table AxisModel error: %v", err)
}
c.Assert(count, Equals, 0)
c.Assert(count, Equals, int64(0))
}

func (t *testDbstoreSuite) TestAxisModelFunc(c *C) {
Expand Down Expand Up @@ -123,7 +123,7 @@ func (t *testDbstoreSuite) TestAxisModelFunc(c *C) {
if err != nil {
c.Fatalf("Count table AxisModel error: %v", err)
}
c.Assert(count, Equals, 0)
c.Assert(count, Equals, int64(0))

err = axisModel.Delete(t.db)
c.Assert(err, IsNil)
Expand Down Expand Up @@ -157,7 +157,7 @@ func (t *testDbstoreSuite) TestAxisModelsFindAndDelete(c *C) {
if err != nil {
c.Fatalf("Count table AxisModel error: %v", err)
}
c.Assert(count, Equals, int(maxLayerNum)*axisModelNumEachLayer)
c.Assert(count, Equals, int64(int(maxLayerNum)*axisModelNumEachLayer))

findLayerNum := maxLayerNum - 1
axisModels, err := FindAxisModelsOrderByTime(t.db, findLayerNum)
Expand All @@ -175,7 +175,7 @@ func (t *testDbstoreSuite) TestAxisModelsFindAndDelete(c *C) {
if err != nil {
c.Fatalf("Count table AxisModel error: %v", err)
}
c.Assert(count, Equals, int(maxLayerNum-1)*axisModelNumEachLayer)
c.Assert(count, Equals, int64(int(maxLayerNum-1)*axisModelNumEachLayer))
}

func axisModelsDeepEqual(obtainedAxisModels []*AxisModel, expectedAxisModels []*AxisModel, c *C) {
Expand Down
4 changes: 2 additions & 2 deletions pkg/pd/client.go
Original file line number Diff line number Diff line change
Expand Up @@ -77,8 +77,8 @@ func (c Client) WithTimeout(timeout time.Duration) *Client {
return &c
}

func (c Client) WithBeforeRequest(callback func(req *http.Request)) *Client {
c.httpClient.BeforeRequest = callback
func (c Client) AddRequestHeader(key, value string) *Client {
c.httpClient = c.httpClient.CloneAndAddRequestHeader(key, value)
return &c
}

Expand Down
52 changes: 52 additions & 0 deletions pkg/pd/client_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,52 @@
// Copyright 2021 PingCAP, Inc. Licensed under Apache-2.0.

package pd

import (
"context"
"net/http"
"net/http/httptest"
"testing"

"github.com/stretchr/testify/require"
"go.uber.org/fx/fxtest"

"github.com/pingcap/tidb-dashboard/pkg/config"
"github.com/pingcap/tidb-dashboard/pkg/httpc"
)

func newTestClient(t *testing.T) *Client {
lc := fxtest.NewLifecycle(t)
config := &config.Config{}
c := NewPDClient(lc, httpc.NewHTTPClient(lc, config), config)
c.lifecycleCtx = context.Background()
return c
}

func Test_AddRequestHeader_returnDifferentHTTPClient(t *testing.T) {
c := newTestClient(t)
cc := c.AddRequestHeader("1", "11")

require.NotSame(t, c.httpClient, cc.httpClient)
}

func Test_Get_withHeader(t *testing.T) {
ts := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
_, _ = w.Write([]byte(r.Header.Get("1")))
}))
defer ts.Close()

c := newTestClient(t).WithBaseURL(ts.URL)
resp1, _ := c.Get("")
d1, _ := resp1.Body()
require.Equal(t, "", string(d1))

cc := c.AddRequestHeader("1", "11")
resp2, _ := cc.Get("")
d2, _ := resp2.Body()
require.Equal(t, "11", string(d2))

resp3, _ := c.Get("")
d3, _ := resp3.Body()
require.Equal(t, "", string(d3))
}
2 changes: 1 addition & 1 deletion release-version
Original file line number Diff line number Diff line change
@@ -1,3 +1,3 @@
# This file specifies the TiDB Dashboard internal version, which will be printed in `--version`
# and UI. In release branch, changing this file will result in publishing a new version and tag.
2021.11.08.1
2021.12.06.1

0 comments on commit bcc43a0

Please sign in to comment.