Skip to content

Commit

Permalink
add rename replication test
Browse files Browse the repository at this point in the history
  • Loading branch information
wuxianrong committed Mar 21, 2024
1 parent 8e802c2 commit a099752
Show file tree
Hide file tree
Showing 6 changed files with 148 additions and 13 deletions.
9 changes: 4 additions & 5 deletions conf/pika.conf
Original file line number Diff line number Diff line change
Expand Up @@ -513,20 +513,19 @@ cache-lfu-decay-time: 1
#
# aclfile : ../conf/users.acl

# (experimental)
# It is possible to change the name of dangerous commands in a shared environment.
# For instance the CONFIG command may be renamed into something Warning: To prevent
# data inconsistency caused by different configuration files, do not use the rename
# command to modify write commands on the primary and secondary servers. If necessary,
# ensure that the configuration files of the primary and secondary servers are consistent
# In addition, when using the command rename, you must not use "" to modify the command,
# for example, rename-command: FLUSHDB "360flushdb" is incorrect; instead, use
# rename-command: FLUSHDB 360flushdb is correct. After the rename command is executed,
# rename-command: FLUSHALL 360flushdb is correct. After the rename command is executed,
# it is most appropriate to use a numeric string with uppercase or lowercase letters
# for example: rename-command : FLUSHDB joYAPNXRPmcarcR4ZDgC81TbdkSmLAzRPmcarcR
#
# Warning: setnx, setex, psetex, expire, pexpire, pexpireat, flushall, padding command
# cannot use rename-command change command name
#
# Warning: Currently only applies to flushdb, slaveof, bgsave, shutdown, config command
# Example:
#
# rename-command : FLUSHDB 360flushdb
#rename-command : FLUSHDB 360flushdb
18 changes: 11 additions & 7 deletions tests/integration/options.go
Original file line number Diff line number Diff line change
Expand Up @@ -7,13 +7,17 @@ import (
)

const (
LOCALHOST = "127.0.0.1"
SLAVEPORT = "9231"
MASTERPORT = "9241"
SINGLEADDR = "127.0.0.1:9221"
SLAVEADDR = "127.0.0.1:9231"
MASTERADDR = "127.0.0.1:9241"
RenameADDR = "127.0.0.1:9251"
LOCALHOST = "127.0.0.1"
SLAVEPORT = "9231"
MASTERPORT = "9241"
SLAVERENAMEPORT = "9888"
MASTERRENAMEPORT = "9777"
SINGLEADDR = "127.0.0.1:9221"
SLAVEADDR = "127.0.0.1:9231"
MASTERADDR = "127.0.0.1:9241"
SLAVERENAMEADDR = "127.0.0.1:9888"
MASTERRENAMEADDR = "127.0.0.1:9777"
RenameADDR = "127.0.0.1:9251"

CODISADDR = "127.0.0.1:19000"

Expand Down
1 change: 0 additions & 1 deletion tests/integration/renamecommand_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -40,5 +40,4 @@ var _ = Describe("Rename Command test", func() {
r = client.Do(ctx, "flushdb")
Expect(r.Val()).NotTo(Equal("OK"))
})

})
88 changes: 88 additions & 0 deletions tests/integration/replication_rename_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,88 @@
package pika_integration

import (
"context"
"log"
"time"

. "github.com/bsm/ginkgo/v2"
. "github.com/bsm/gomega"
"github.com/redis/go-redis/v9"
)

var _ = Describe("should replication rename", func() {
Describe("all replication rename test", func() {
ctx := context.TODO()
var clientSlave *redis.Client
var clientMaster *redis.Client

BeforeEach(func() {
clientMaster = redis.NewClient(PikaOption(MASTERRENAMEADDR))
clientSlave = redis.NewClient(PikaOption(SLAVERENAMEADDR))
cleanEnv(ctx, clientMaster, clientSlave)
if GlobalBefore != nil {
GlobalBefore(ctx, clientMaster)
GlobalBefore(ctx, clientSlave)
}
})
AfterEach(func() {
cleanEnv(ctx, clientMaster, clientSlave)
Expect(clientSlave.Close()).NotTo(HaveOccurred())
Expect(clientMaster.Close()).NotTo(HaveOccurred())
log.Println("Replication test case done")
})

It("Let The slave become a replica of The master ", func() {
infoRes := clientSlave.Info(ctx, "replication")
Expect(infoRes.Err()).NotTo(HaveOccurred())
Expect(infoRes.Val()).To(ContainSubstring("role:master"))
infoRes = clientMaster.Info(ctx, "replication")
Expect(infoRes.Err()).NotTo(HaveOccurred())
Expect(infoRes.Val()).To(ContainSubstring("role:master"))
Expect(clientSlave.Do(ctx, "slaveof", LOCALHOST, SLAVERENAMEPORT).Err()).To(MatchError("ERR The master ip:port and the slave ip:port are the same"))

var count = 0
for {
res := trySlave(ctx, clientSlave, LOCALHOST, MASTERRENAMEPORT)
if res {
break
} else if count > 4 {
break
} else {
cleanEnv(ctx, clientMaster, clientSlave)
count++
}
}

infoRes = clientSlave.Info(ctx, "replication")
Expect(infoRes.Err()).NotTo(HaveOccurred())
Expect(infoRes.Val()).To(ContainSubstring("master_link_status:up"))

infoRes = clientMaster.Info(ctx, "replication")
Expect(infoRes.Err()).NotTo(HaveOccurred())
Expect(infoRes.Val()).To(ContainSubstring("connected_slaves:1"))

slaveWrite := clientSlave.Set(ctx, "foo", "bar", 0)
Expect(slaveWrite.Err()).To(MatchError("ERR Server in read-only"))
log.Println("Replication rename test 1 start")
set := clientMaster.Set(ctx, "x", "y", 0)
Expect(set.Err()).NotTo(HaveOccurred())
Expect(set.Val()).To(Equal("OK"))
set1 := clientMaster.Set(ctx, "a", "b", 0)
Expect(set1.Err()).NotTo(HaveOccurred())
Expect(set1.Val()).To(Equal("OK"))
r1 := clientMaster.Do(ctx, "flushdb")
Expect(r1.Val()).NotTo(Equal("OK"))
time.Sleep(3 * time.Second)
Expect(clientMaster.Do(ctx, "360flushdb").Err()).NotTo(HaveOccurred())
Eventually(func() error {
return clientMaster.Get(ctx, "x").Err()
}, "60s", "100ms").Should(Equal(redis.Nil))
Eventually(func() error {
return clientSlave.Get(ctx, "x").Err()
}, "60s", "100ms").Should(Equal(redis.Nil))
log.Println("Replication rename test 1 success")

})
})
})
17 changes: 17 additions & 0 deletions tests/integration/server_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,23 @@ var _ = Describe("Server", func() {
})

Describe("server", func() {
It("Cmd Select", func() {
r, e := client.Set(ctx, "key", "foobar", 0).Result()
Expect(e).NotTo(HaveOccurred())
Expect(r).To(Equal("OK"))

get := client.Get(ctx, "key")
Expect(get.Err()).NotTo(HaveOccurred())
Expect(get.Val()).To(Equal("foobar"))

rs := client.Do(ctx, "select", "1")
Expect(rs.Err()).NotTo(HaveOccurred())
Expect(rs.Val()).To(Equal("OK"))

get1 := client.Get(ctx, "key")
Expect(get1.Err()).NotTo(HaveOccurred())
Expect(get1.Val()).To(Equal(redis.Nil))
})
It("should Auth", func() {
cmds, err := client.Pipelined(ctx, func(pipe redis.Pipeliner) error {
pipe.Auth(ctx, "112121")
Expand Down
28 changes: 28 additions & 0 deletions tests/integration/start_master_and_slave.sh
Original file line number Diff line number Diff line change
Expand Up @@ -6,12 +6,16 @@ cp ../conf/pika.conf ./pika_single.conf
cp ../conf/pika.conf ./pika_master.conf
cp ../conf/pika.conf ./pika_slave.conf
cp ../conf/pika.conf ./pika_rename.conf
cp ../conf/pika.conf ./pika_master_rename.conf
cp ../conf/pika.conf ./pika_slave_rename.conf
cp ../conf/pika.conf ./pika_acl_both_password.conf
cp ../conf/pika.conf ./pika_acl_only_admin_password.conf
cp ../conf/pika.conf ./pika_has_other_acl_user.conf
# Create folders for storing data on the primary and secondary nodes
mkdir master_data
mkdir slave_data
mkdir master_data_rename
mkdir slave_data_rename
# Example Change the location for storing data on primary and secondary nodes in the configuration file
sed -i '' \
-e 's|databases : 1|databases : 2|' \
Expand All @@ -37,6 +41,28 @@ sed -i '' \
-e 's|db-sync-path : ./dbsync/|db-sync-path : ./slave_data/dbsync/|' \
-e 's|#daemonize : yes|daemonize : yes|' ./pika_slave.conf

sed -i '' \
-e 's|# rename-command : FLUSHDB 360flushdb|rename-command : FLUSHDB 360flushdb|' \
-e 's|databases : 1|databases : 2|' \
-e 's|port : 9221|port : 9777|' \
-e 's|log-path : ./log/|log-path : ./master_data_rename/log/|' \
-e 's|db-path : ./db/|db-path : ./master_data_rename/db/|' \
-e 's|dump-path : ./dump/|dump-path : ./master_data_rename/dump/|' \
-e 's|pidfile : ./pika.pid|pidfile : ./master_data_rename/pika.pid|' \
-e 's|db-sync-path : ./dbsync/|db-sync-path : ./master_data_rename/dbsync/|' \
-e 's|#daemonize : yes|daemonize : yes|' ./pika_master_rename.conf

sed -i '' \
-e 's|# rename-command : FLUSHDB 360flushdb|rename-command : FLUSHDB 360flushdb|' \
-e 's|databases : 1|databases : 2|' \
-e 's|port : 9221|port : 9888|' \
-e 's|log-path : ./log/|log-path : ./slave_data_rename/log/|' \
-e 's|db-path : ./db/|db-path : ./slave_data_rename/db/|' \
-e 's|dump-path : ./dump/|dump-path : ./slave_data_rename/dump/|' \
-e 's|pidfile : ./pika.pid|pidfile : ./slave_data_rename/pika.pid|' \
-e 's|db-sync-path : ./dbsync/|db-sync-path : ./slave_data_rename/dbsync/|' \
-e 's|#daemonize : yes|daemonize : yes|' ./pika_slave_rename.conf

sed -i '' \
-e 's|# rename-command : FLUSHDB 360flushdb|rename-command : FLUSHDB 360flushdb|' \
-e 's|databases : 1|databases : 2|' \
Expand Down Expand Up @@ -94,5 +120,7 @@ echo -e '\nuser : limit on >limitpass ~* +@all &*' >> ./pika_has_other_acl_user.
./pika -c ./pika_acl_both_password.conf
./pika -c ./pika_acl_only_admin_password.conf
./pika -c ./pika_has_other_acl_user.conf
./pika -c ./pika_master_rename.conf
./pika -c ./pika_slave_rename.conf
#ensure both master and slave are ready
sleep 10

0 comments on commit a099752

Please sign in to comment.