Skip to content

Commit

Permalink
Merge pull request #1929 from dedis/work-be1-stuart-add-publish-test
Browse files Browse the repository at this point in the history
[BE1] Add publish test
  • Loading branch information
sgueissa committed Jun 14, 2024
2 parents 8268cc6 + 415469c commit 61aa18f
Show file tree
Hide file tree
Showing 4 changed files with 197 additions and 0 deletions.
42 changes: 42 additions & 0 deletions be1-go/internal/handler/method/publish/hpublish/mocks/hub.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

57 changes: 57 additions & 0 deletions be1-go/internal/handler/method/publish/hpublish/publish_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,57 @@
package hpublish

import (
"github.com/stretchr/testify/require"
"popstellar/internal/handler/method/publish/hpublish/mocks"
"popstellar/internal/logger"
mocks2 "popstellar/internal/network/socket/mocks"
"popstellar/internal/test/generator"
"testing"
)

func Test_Handle(t *testing.T) {
log := logger.Logger.With().Str("test", "Handle").Logger()

hub := mocks.NewHub(t)
messageHandler := mocks.NewMessageHandler(t)
db := mocks.NewRepository(t)

publishHandler := New(hub, db, messageHandler, log)

socket := mocks2.NewFakeSocket("0")

queryID := 0
channelPath := "/root"
msg := generator.NewNothingMsg(t, "sender", nil)
publishBuf := generator.NewPublishQuery(t, queryID, channelPath, msg)

// succeed handling the publish + notify new rumor

messageHandler.On("Handle", channelPath, msg, false).Return(nil).Once()
db.On("AddMessageToMyRumor", msg.MessageID).Return(thresholdMessagesByRumor, nil).Once()
hub.On("NotifyResetRumorSender").Return(nil).Once()

id, err := publishHandler.Handle(socket, publishBuf)
require.Nil(t, id)
require.NoError(t, err)

// succeed handling the publish but no notify rumor

messageHandler.On("Handle", channelPath, msg, false).Return(nil).Once()
db.On("AddMessageToMyRumor", msg.MessageID).Return(thresholdMessagesByRumor-1, nil).Once()

id, err = publishHandler.Handle(socket, publishBuf)
require.Nil(t, id)
require.NoError(t, err)

// succeed handling the publish but no rumor because federation channel

channelPath = "/root/laoID/federation"
publishBuf = generator.NewPublishQuery(t, queryID, channelPath, msg)

messageHandler.On("Handle", channelPath, msg, false).Return(nil).Once()

id, err = publishHandler.Handle(socket, publishBuf)
require.Nil(t, id)
require.NoError(t, err)
}

0 comments on commit 61aa18f

Please sign in to comment.