1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73
|
package importer
import (
"encoding/hex"
"io/ioutil"
"log"
"testing"
"github.com/twstrike/gotk3adapter/glib_mock"
"github.com/twstrike/coyim/i18n"
. "gopkg.in/check.v1"
)
func Test(t *testing.T) { TestingT(t) }
func init() {
log.SetOutput(ioutil.Discard)
i18n.InitLocalization(&glib_mock.Mock{})
}
type XmppClientXmppSuite struct{}
var _ = Suite(&XmppClientXmppSuite{})
func decode(in string) []byte {
ret, _ := hex.DecodeString(in)
return ret
}
func (s *XmppClientXmppSuite) Test_XmppClient_canImportXmppClientConfiguration(c *C) {
importer := xmppClientImporter{}
res, ok := importer.importFrom(testResourceFilename("xmpp_client_test_conf.json"))
c.Assert(ok, Equals, true)
c.Assert(len(res.Accounts), Equals, 1)
c.Assert(res.Accounts[0].Account, Equals, "ox@coyim.net")
c.Assert(res.Accounts[0].Server, Equals, "xmpp.coyim.net")
c.Assert(res.Accounts[0].Proxies[0], Equals, "socks5://127.0.0.1:9051")
c.Assert(res.Accounts[0].Password, Equals, "123547567846rghdfghdrghr6ythdt")
c.Assert(res.Accounts[0].Port, Equals, 5223)
c.Assert(res.Accounts[0].HideStatusUpdates, Equals, true)
c.Assert(res.Accounts[0].OTRAutoTearDown, Equals, true)
c.Assert(res.Accounts[0].OTRAutoAppendTag, Equals, true)
c.Assert(res.Accounts[0].OTRAutoStartSession, Equals, true)
c.Assert(res.Accounts[0].LegacyServerCertificateSHA256, Equals, "592f46183527ab40838882ab4cb4aef4e2cf916074ab01f9bc243931ca5c4ed1")
c.Assert(res.Accounts[0].PrivateKeys[0], DeepEquals, []byte{0x00, 0x10, 0x80, 0x04, 0x20, 0x01})
c.Assert(res.Accounts[0].AlwaysEncrypt, Equals, true)
c.Assert(res.Accounts[0].AlwaysEncryptWith, DeepEquals, []string(nil))
c.Assert(res.Accounts[0].InstanceTag, Equals, uint32(0))
c.Assert(len(res.Accounts[0].LegacyKnownFingerprints), Equals, 0)
// c.Assert(res.Accounts[0].KnownFingerprints[0].UserID, Equals, "arnold@jabber.ccc.de")
// c.Assert(res.Accounts[0].KnownFingerprints[0].Fingerprint, DeepEquals, decode("c2a23b8e8852bff5335b39b674ceec13228be0af"))
// c.Assert(res.Accounts[0].KnownFingerprints[0].Untrusted, Equals, false)
// c.Assert(res.Accounts[0].KnownFingerprints[1].UserID, Equals, "some@one.com")
// c.Assert(res.Accounts[0].KnownFingerprints[1].Fingerprint, DeepEquals, decode("410aad3ce865b83ed564b2e1ce52882b07b00976"))
// c.Assert(res.Accounts[0].KnownFingerprints[1].Untrusted, Equals, false)
// c.Assert(res.Accounts[0].KnownFingerprints[2].UserID, Equals, "hello@riseup.net")
// c.Assert(res.Accounts[0].KnownFingerprints[2].Fingerprint, DeepEquals, decode("50ae9522641401e1a58de568fc4b265493d451b4"))
// c.Assert(res.Accounts[0].KnownFingerprints[2].Untrusted, Equals, false)
// c.Assert(res.Accounts[0].KnownFingerprints[3].UserID, Equals, "second.hello@riseup.net")
// c.Assert(res.Accounts[0].KnownFingerprints[3].Fingerprint, DeepEquals, decode("4da542fdd60e077b38b05aa3485916d5d7c958aa"))
// c.Assert(res.Accounts[0].KnownFingerprints[3].Untrusted, Equals, false)
c.Assert(res.Bell, Equals, true)
c.Assert(res.Display.MergeAccounts, Equals, false)
c.Assert(res.Display.ShowOnlyOnline, Equals, false)
c.Assert(res.RawLogFile, Equals, "bla")
c.Assert(res.NotifyCommand, DeepEquals, []string{"hello"})
c.Assert(res.IdleSecondsBeforeNotification, Equals, 42)
}
|