diff options
author | cori hudson <54032873+hyperobject@users.noreply.github.com> | 2019-08-26 15:00:31 -0400 |
---|---|---|
committer | Wim <wim@42.be> | 2019-08-26 21:00:31 +0200 |
commit | 921f2dfcdf1a6263220b55eb55716e497373dfcf (patch) | |
tree | 436478bd7b61ea598d75af0d27520b512dad1683 /vendor/github.com/keybase/go-keybase-chat-bot/kbchat/test_utils.go | |
parent | 79a006c8de311a7bbab540e62bd3fac998d415d5 (diff) | |
download | matterbridge-msglm-921f2dfcdf1a6263220b55eb55716e497373dfcf.tar.gz matterbridge-msglm-921f2dfcdf1a6263220b55eb55716e497373dfcf.tar.bz2 matterbridge-msglm-921f2dfcdf1a6263220b55eb55716e497373dfcf.zip |
Add initial Keybase Chat support (#877)
* initial work on native keybase bridging
* Hopefully make a functional keybase bridge
* add keybase to bridgemap
* send to right channel, try to figure out received msgs
* add account and userid
* i am a Dam Fool
* Fix formatting for messages, handle /me
* update vendors, ran golint and goimports
* move handlers to handlers.go, clean up unused config options
* add sample config, fix inconsistent remote nick handling
* Update readme with keybase links
* Resolve fixmie errors
* Error -> Errorf
* fix linting errors in go.mod and go.sum
* explicitly join channels, ignore messages from non-specified channels
* check that team names match before bridging message
Diffstat (limited to 'vendor/github.com/keybase/go-keybase-chat-bot/kbchat/test_utils.go')
-rw-r--r-- | vendor/github.com/keybase/go-keybase-chat-bot/kbchat/test_utils.go | 54 |
1 files changed, 54 insertions, 0 deletions
diff --git a/vendor/github.com/keybase/go-keybase-chat-bot/kbchat/test_utils.go b/vendor/github.com/keybase/go-keybase-chat-bot/kbchat/test_utils.go new file mode 100644 index 00000000..1a163951 --- /dev/null +++ b/vendor/github.com/keybase/go-keybase-chat-bot/kbchat/test_utils.go @@ -0,0 +1,54 @@ +package kbchat + +import ( + "crypto/rand" + "encoding/hex" + "io/ioutil" + "os" + "os/exec" + "path" + "strings" + "testing" + + "github.com/stretchr/testify/require" +) + +func randomString(t *testing.T) string { + bytes := make([]byte, 16) + _, err := rand.Read(bytes) + require.NoError(t, err) + return hex.EncodeToString(bytes) +} + +func randomTempDir(t *testing.T) string { + return path.Join(os.TempDir(), "keybase_bot_"+randomString(t)) +} + +func whichKeybase(t *testing.T) string { + cmd := exec.Command("which", "keybase") + out, err := cmd.Output() + require.NoError(t, err) + location := strings.TrimSpace(string(out)) + return location +} + +func copyFile(t *testing.T, source, dest string) { + sourceData, err := ioutil.ReadFile(source) + require.NoError(t, err) + err = ioutil.WriteFile(dest, sourceData, 0777) + require.NoError(t, err) +} + +// Creates the working directory and copies over the keybase binary in PATH. +// We do this to avoid any version mismatch issues. +func prepWorkingDir(t *testing.T, workingDir string) string { + kbLocation := whichKeybase(t) + + err := os.Mkdir(workingDir, 0777) + require.NoError(t, err) + kbDestination := path.Join(workingDir, "keybase") + + copyFile(t, kbLocation, kbDestination) + + return kbDestination +} |