All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.github.lombrozo.testnames.TestClass Maven / Gradle / Ivy

/*
 * MIT License
 *
 * Copyright (c) 2022-2024 Volodya Lombrozo
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to deal
 * in the Software without restriction, including without limitation the rights
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in all
 * copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
 * SOFTWARE.
 */
package com.github.lombrozo.testnames;

import java.nio.file.Path;
import java.nio.file.Paths;
import java.util.Arrays;
import java.util.Collection;
import java.util.Collections;
import java.util.List;
import lombok.Data;

/**
 * The bulk of test cases.
 *
 * @since 0.1.0
 */
public interface TestClass {

    /**
     * The name of class.
     *
     * @return The name of class as string
     */
    String name();

    /**
     * All cases.
     *
     * @return All cases as collection
     */
    Collection all();

    /**
     * Path to the class.
     * @return Path to the class.
     */
    Path path();

    /**
     * The suppressed rules.
     * @return The suppressed rules.
     */
    Collection suppressed();

    /**
     * The characteristics of the test class.
     * @return The characteristics of the test class.
     */
    TestClassCharacteristics characteristics();

    /**
     * The fake test class.
     *
     * @since 0.2
     * @checkstyle ParameterNumberCheck (500 lines)
     */
    @Data
    final class Fake implements TestClass {

        /**
         * The default name of the Fake test class.
         */
        private static final String DEFAULT_NAME = "FakeClassTest";

        /**
         * The name of test class.
         */
        private final String name;

        /**
         * All cases.
         */
        private final Collection all;

        /**
         * All suppressed rules.
         */
        private final List suppressed;

        /**
         * Test class characteristics.
         */
        private final TestClassCharacteristics props;

        /**
         * Primary ctor.
         */
        public Fake() {
            this(Fake.DEFAULT_NAME, Collections.emptyList(), Collections.emptyList());
        }

        /**
         * Constructor.
         * @param all All cases
         */
        public Fake(final TestCase... all) {
            this(Fake.DEFAULT_NAME, all);
        }

        /**
         * Primary ctor.
         * @param extension Is JUnit extension
         */
        public Fake(final boolean extension) {
            this(
                Fake.DEFAULT_NAME,
                Collections.emptyList(),
                Collections.emptyList(),
                new TestClassCharacteristics.Fake(extension)
            );
        }

        /**
         * Ctor.
         * @param name Class name
         * @param all All cases
         */
        public Fake(final String name, final TestCase... all) {
            this(name, Arrays.asList(all), Collections.emptyList());
        }

        /**
         * Create fake test class with suppressed rules.
         * @param suppressed Suppressed rules
         */
        public Fake(final List suppressed) {
            this(Fake.DEFAULT_NAME, Collections.emptyList(), suppressed);
        }

        /**
         * Create fake test class with suppressed rules.
         * @param suppressed Suppressed rules
         * @param all All cases
         */
        public Fake(final List suppressed, final TestCase... all) {
            this(Fake.DEFAULT_NAME, Arrays.asList(all), suppressed);
        }

        /**
         * Constructor.
         * @param props Test class characteristics
         */
        public Fake(final TestClassCharacteristics props) {
            this(
                Fake.DEFAULT_NAME,
                Collections.emptyList(),
                Collections.emptyList(),
                props
            );
        }

        /**
         * Constructor.
         * @param name The name of test class
         * @param all All cases
         * @param suppressed All suppressed rules
         */
        Fake(
            final String name,
            final Collection all,
            final List suppressed
        ) {
            this(name, all, suppressed, new TestClassCharacteristics.Fake(false));
        }

        /**
         * Constructor.
         * @param parent The parent class name
         */
        Fake(final String parent) {
            this(
                Fake.DEFAULT_NAME,
                Collections.emptyList(),
                Collections.emptyList(),
                new TestClassCharacteristics.Fake(parent)
            );
        }

        /**
         * Main ctor.
         * @param name The name of test class
         * @param all All cases
         * @param suppressed All suppressed rules
         * @param props Test class characteristics
         */
        Fake(
            final String name,
            final Collection all,
            final List suppressed,
            final TestClassCharacteristics props
        ) {
            this.name = name;
            this.all = all;
            this.suppressed = suppressed;
            this.props = props;
        }

        @Override
        public String name() {
            return this.name;
        }

        @Override
        public Collection all() {
            return Collections.unmodifiableCollection(this.all);
        }

        @Override
        public Path path() {
            return Paths.get(this.name);
        }

        @Override
        public Collection suppressed() {
            return Collections.unmodifiableList(this.suppressed);
        }

        @Override
        public TestClassCharacteristics characteristics() {
            return this.props;
        }
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy