| /* |
| * |
| * 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 |