view web/server/src/test/java/com/redhat/thermostat/web/server/KnownDescriptorRegistryTest.java @ 2049:a92d602216ad

Update copyright license headers for 2017 PR3290 Reviewed-by: jerboaa Review-thread: http://icedtea.classpath.org/pipermail/thermostat/2017-January/021974.html
author Andrew Azores <aazores@redhat.com>
date Tue, 17 Jan 2017 12:19:56 -0500
parents 31f274ab27a5
children
line wrap: on
line source

/*
 * Copyright 2012-2017 Red Hat, Inc.
 *
 * This file is part of Thermostat.
 *
 * Thermostat is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published
 * by the Free Software Foundation; either version 2, or (at your
 * option) any later version.
 *
 * Thermostat is distributed in the hope that it will be useful, but
 * WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with Thermostat; see the file COPYING.  If not see
 * <http://www.gnu.org/licenses/>.
 *
 * Linking this code with other modules is making a combined work
 * based on this code.  Thus, the terms and conditions of the GNU
 * General Public License cover the whole combination.
 *
 * As a special exception, the copyright holders of this code give
 * you permission to link this code with independent modules to
 * produce an executable, regardless of the license terms of these
 * independent modules, and to copy and distribute the resulting
 * executable under terms of your choice, provided that you also
 * meet, for each linked independent module, the terms and conditions
 * of the license of that module.  An independent module is a module
 * which is not derived from or based on this code.  If you modify
 * this code, you may extend this exception to your version of the
 * library, but you are not obligated to do so.  If you do not wish
 * to do so, delete this exception statement from your version.
 */

package com.redhat.thermostat.web.server;

import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertTrue;
import static org.junit.Assert.fail;

import java.util.Arrays;
import java.util.HashSet;
import java.util.Set;
import java.util.TreeSet;

import org.junit.Test;

import com.redhat.thermostat.storage.core.PreparedParameter;
import com.redhat.thermostat.storage.core.auth.DescriptorMetadata;
import com.redhat.thermostat.storage.core.auth.StatementDescriptorRegistration;

public class KnownDescriptorRegistryTest {

    @Test
    public void canAddDescriptors() {
        Set<String> descs = new HashSet<>();
        descs.add("QUERY test WHERE 'a' = ?s");
        descs.add("QUERY agent-config");
        Iterable<StatementDescriptorRegistration> regs = getRegs(descs);
        KnownDescriptorRegistry reg = new KnownDescriptorRegistry(regs);
        Set<String> registeredDescs = null;
        try {
            registeredDescs = reg.getRegisteredDescriptors();
        } catch (IllegalStateException e) {
            fail(e.getMessage());
        }
        assertNotNull(registeredDescs);
        for (String d: registeredDescs) {
            assertTrue(descs.contains(d));
        }
    }
    
    @Test
    public void testServiceLoadersInClassPath() {
        KnownDescriptorRegistry reg = new KnownDescriptorRegistry();
        Set<String> trustedDescs = reg.getRegisteredDescriptors();
        assertNotNull(trustedDescs);
        // storage-core registers 24 descriptors; this module has
        // only storage-core as maven dep which registers queries.
        // see DAOImplStatementDescriptorRegistration
        assertEquals(24, trustedDescs.size());
    }
    
    /**
     * Tests that {@code set.contains(null)} does not throw exceptions since
     * plug-ins may supply any {@link Set} implementation. {@link TreeSet} for
     * example throws a NPE if such a check is attempted.
     * 
     * See: http://icedtea.classpath.org/bugzilla/show_bug.cgi?id=2077
     */
    @Test
    public void testNullCheckWithTreeSet() {
        String desc = "QUERY test WHERE 'a' = ?s";
        Set<String> descs = new TreeSet<>();
        descs.add(desc);
        try {
            descs.add(null);
            fail("Expected NPE when adding null to TreeSet");
        } catch (NullPointerException e) {
            // pre-condition passes
        }
        Iterable<StatementDescriptorRegistration> regs = getRegs(descs);
        KnownDescriptorRegistry registry = null;
        try {
            registry = new KnownDescriptorRegistry(regs);
            // pass
        } catch (NullPointerException npe) {
            npe.printStackTrace();
            fail("Should not have thrown NPE");
        }
        assertTrue("descriptor should be known", registry.getRegisteredDescriptors().contains(desc));
    }
    
    @Test
    public void cannotAddNullDescriptors() {
        Set<String> descs = new HashSet<>();
        descs.add("QUERY test WHERE 'a' = ?s");
        descs.add(null);
        Iterable<StatementDescriptorRegistration> regs = getRegs(descs);
        try {
            new KnownDescriptorRegistry(regs);
            fail("Should not have accepted null descriptor");
        } catch (IllegalStateException e) {
            assertEquals("null statement descriptor not acceptable!", e.getMessage());
        }
    }

    private Iterable<StatementDescriptorRegistration> getRegs(Set<String> descs) {
        StatementDescriptorRegistration reg = new TestStatementDescriptorRegistration(
                descs);
        StatementDescriptorRegistration[] regs = new StatementDescriptorRegistration[] { reg };
        return Arrays.asList(regs);
    }
    
    private static class TestStatementDescriptorRegistration implements StatementDescriptorRegistration {

        private final Set<String> descs;
        
        private TestStatementDescriptorRegistration(Set<String> descs) {
            this.descs = descs;
        }
        
        @Override
        public Set<String> getStatementDescriptors() {
            return descs;
        }

        @Override
        public DescriptorMetadata getDescriptorMetadata(String descriptor,
                PreparedParameter[] params) {
            throw new AssertionError("should not be used");
        }
        
    }
}