/* * * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance * with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY * KIND, either express or implied. See the License for the * specific language governing permissions and limitations * under the License. * */ using System; using System.Collections; using System.Text; using NUnit.Framework; using Apache.Qpid.Sasl; using Apache.Qpid.Sasl.Mechanisms; namespace Apache.Qpid.Sasl.Tests.Mechanisms { [TestFixture] public class CramMD5SaslClientTests : ISaslCallbackHandler { private const string USERNAME = "testuser"; private const string PASSWORD = "tanstaaftanstaaf"; private const string AUTHID = "test"; [Test] public void ReturnsRightMechanismName() { ISaslClient client = new CramMD5SaslClient(AUTHID, new Hashtable(), this); Assert.AreEqual("CRAM-MD5", client.MechanismName); } [Test] public void HasInitialResponseReturnsFalse() { ISaslClient client = new CramMD5SaslClient(AUTHID, new Hashtable(), this); Assert.IsFalse(client.HasInitialResponse); } [Test] public void CanEvaluateChallenge() { Hashtable props = new Hashtable(); ISaslClient client = new CramMD5SaslClient(AUTHID, props, this); Assert.IsFalse(client.IsComplete); byte[] challenge = Encoding.UTF8.GetBytes("<1896.697170952@postoffice.reston.mci.net>"); byte[] response = client.EvaluateChallenge(challenge); string[] parts = Encoding.UTF8.GetString(response).Split(' '); Assert.AreEqual(2, parts.Length); Assert.AreEqual(USERNAME, parts[0]); Assert.AreEqual("b913a602c7eda7a495b4e6e7334d3890", parts[1]); Assert.IsTrue(client.IsComplete); } void ISaslCallbackHandler.Handle(ISaslCallback[] callbacks) { foreach ( ISaslCallback cb in callbacks ) { if ( cb is NameCallback ) { ((NameCallback)cb).Text = USERNAME; } else if ( cb is PasswordCallback ) { ((PasswordCallback)cb).Text = PASSWORD; } } } } // class CramMD5SaslClientTests } // namespace Apache.Qpid.Sasl.Tests.Mechanisms