/*
* dnssecjava - a DNSSEC validating stub resolver for Java
* Copyright (c) 2013-2015 Ingo Bauersachs
*
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*/
package org.jitsi.dnssec;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertFalse;
import java.io.IOException;
import org.junit.Test;
import org.xbill.DNS.Flags;
import org.xbill.DNS.Message;
import org.xbill.DNS.Rcode;
public class TestKeyCacheUsage extends TestBase {
@Test
public void testUnsigned() throws IOException {
Message response = resolver.send(createMessage("www.unsigned.ingotronic.ch./A"));
assertFalse("AD flag must not be set", response.getHeader().getFlag(Flags.AD));
assertEquals(Rcode.NOERROR, response.getRcode());
assertEquals(localhost, firstA(response));
assertEquals("insecure.ds.nsec", getReason(response));
// send the query a second time to ensure the cache doesn't create a wrong behavior
response = resolver.send(createMessage("www.unsigned.ingotronic.ch./A"));
assertFalse("AD flag must not be set", response.getHeader().getFlag(Flags.AD));
assertEquals(Rcode.NOERROR, response.getRcode());
assertEquals(localhost, firstA(response));
assertEquals("insecure.ds.nsec", getReason(response));
}
}