• Home
  • Features
  • Pricing
  • Docs
  • Announcements
  • Sign In

evolvedbinary / elemental / 982

29 Apr 2025 08:34PM UTC coverage: 56.409% (+0.007%) from 56.402%
982

push

circleci

adamretter
[feature] Improve README.md badges

28451 of 55847 branches covered (50.94%)

Branch coverage included in aggregate %.

77468 of 131924 relevant lines covered (58.72%)

0.59 hits per line

Source File
Press 'n' to go to next uncovered line, 'b' for previous

80.0
/exist-core/src/main/java/org/exist/util/NamedThreadGroupFactory.java
1
/*
2
 * Elemental
3
 * Copyright (C) 2024, Evolved Binary Ltd
4
 *
5
 * admin@evolvedbinary.com
6
 * https://www.evolvedbinary.com | https://www.elemental.xyz
7
 *
8
 * Use of this software is governed by the Business Source License 1.1
9
 * included in the LICENSE file and at www.mariadb.com/bsl11.
10
 *
11
 * Change Date: 2028-04-27
12
 *
13
 * On the date above, in accordance with the Business Source License, use
14
 * of this software will be governed by the Apache License, Version 2.0.
15
 *
16
 * Additional Use Grant: Production use of the Licensed Work for a permitted
17
 * purpose. A Permitted Purpose is any purpose other than a Competing Use.
18
 * A Competing Use means making the Software available to others in a commercial
19
 * product or service that: substitutes for the Software; substitutes for any
20
 * other product or service we offer using the Software that exists as of the
21
 * date we make the Software available; or offers the same or substantially
22
 * similar functionality as the Software.
23
 */
24
package org.exist.util;
25

26
import javax.annotation.Nullable;
27
import java.util.concurrent.atomic.AtomicLong;
28

29
/**
30
 * A simple factory for thread groups, where you
31
 * may want multiple groups with similar names.
32
 *
33
 * @author <a href="mailto:adam@evolvedbinary.com">Adam Retter</a>
34
 */
35
public class NamedThreadGroupFactory {
36

37
    private final String threadGroupNameBase;
38
    private final AtomicLong threadGroupId = new AtomicLong();
1✔
39

40
    /**
41
     * @param threadGroupNameBase the base name for the thread group.
42
     */
43
    public NamedThreadGroupFactory(final String threadGroupNameBase) {
1✔
44
        this.threadGroupNameBase = threadGroupNameBase;
1✔
45
    }
1✔
46

47
    /**
48
     * Produces a thread group named like:
49
     *     "${threadGroupNameBase}-${id}"
50
     *
51
     * Where id is a global monontonically increasing identifier.
52
     *
53
     * @param parent the parent thread group, or null to use the current threads thread group.
54
     *
55
     * @return the new thread group
56
     */
57
    public ThreadGroup newThreadGroup(@Nullable final ThreadGroup parent) {
58
        final String threadGroupName = threadGroupNameBase + "-" + threadGroupId.getAndIncrement();
1✔
59
        if (parent != null) {
1!
60
            return new ThreadGroup(parent, threadGroupName);
×
61
        } else {
62
            return new ThreadGroup(threadGroupName);
1✔
63
        }
64
    }
65
}
STATUS · Troubleshooting · Open an Issue · Sales · Support · CAREERS · ENTERPRISE · START FREE · SCHEDULE DEMO
ANNOUNCEMENTS · TWITTER · TOS & SLA · Supported CI Services · What's a CI service? · Automated Testing

© 2025 Coveralls, Inc