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

org.gradle.util.ports.ReservedPortRangeTest.groovy Maven / Gradle / Ivy

There is a newer version: 8.11.1
Show newest version
/*
 * Copyright 2015 the original author or authors.
 *
 * Licensed 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.
 */

package org.gradle.util.ports

import spock.lang.Specification


class ReservedPortRangeTest extends Specification {
    static final int FIRST_PORT = 101
    static final int LAST_PORT = 110
    ReservedPortRange range = new ReservedPortRange(FIRST_PORT, LAST_PORT)
    PortDetector portDetector = Mock(PortDetector)

    def setup() {
        range.portDetector = portDetector
    }

    def "can allocate unique ports in port range"() {
        def reserved = []

        when:
        10.times {
            reserved.add(range.allocate())
        }

        then:
        10 * portDetector.isAvailable(_) >> { true }

        and:
        reserved.sort() == FIRST_PORT..LAST_PORT
    }

    def "cannot allocate more ports than in range" () {
        when:
        10.times {
            range.allocate()
        }

        then:
        10 * portDetector.isAvailable(_) >> { true }

        and:
        range.allocate() == -1
    }

    def "ports are allocated in sequence" () {
        when:
        def port1 = range.allocate()
        def port2 = range.allocate()
        def port3 = range.allocate()

        then:
        port2 == next(port1)
        port3 == next(port2)

        and:
        3 * portDetector.isAvailable(_) >> { true }
    }

    def "detects when ports are unavailable" () {
        def reserved = []

        when:
        8.times {
            reserved.add(range.allocate())
        }

        then:
        _ * portDetector.isAvailable(_) >> { int port -> return ! (port in [103,107]) }

        and:
        ! reserved.contains(103)
        ! reserved.contains(107)

        and:
        range.allocate() == -1
    }

    def "can deallocate ports" () {
        def reserved = []
        _ * portDetector.isAvailable(_) >> { true }

        when:
        4.times {
            reserved.add(range.allocate())
        }

        then:
        range.allocated.size() == 4

        when:
        reserved.each { int port ->
            range.deallocate(port)
        }

        then:
        range.allocated.size() == 0
    }

    def "can reuse deallocated ports" () {
        _ * portDetector.isAvailable(_) >> { true }

        when:
        10.times {
            range.allocate()
        }

        then:
        range.allocate() == -1

        when:
        range.deallocate(103)
        range.deallocate(109)
        range.deallocate(102)

        then:
        (0..2).collect { range.allocate() }.sort() == [102, 103, 109]
    }

    int next(int port) {
        return port == LAST_PORT ? FIRST_PORT : port+1
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy