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

jreleaser / jreleaser / #556

22 Nov 2025 04:17PM UTC coverage: 46.213% (-2.0%) from 48.203%
#556

push

github

aalmiray
feat(jdks): Allow filtering by platform

Closes #2000

Co-authored-by: Ixchel Ruiz <ixchelruiz@yahoo.com>

0 of 42 new or added lines in 5 files covered. (0.0%)

1116 existing lines in 107 files now uncovered.

24939 of 53965 relevant lines covered (46.21%)

0.46 hits per line

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

37.86
/core/jreleaser-engine/src/main/java/org/jreleaser/engine/upload/Uploaders.java
1
/*
2
 * SPDX-License-Identifier: Apache-2.0
3
 *
4
 * Copyright 2020-2025 The JReleaser authors.
5
 *
6
 * Licensed under the Apache License, Version 2.0 (the "License");
7
 * you may not use this file except in compliance with the License.
8
 * You may obtain a copy of the License at
9
 *
10
 *     https://www.apache.org/licenses/LICENSE-2.0
11
 *
12
 * Unless required by applicable law or agreed to in writing, software
13
 * distributed under the License is distributed on an "AS IS" BASIS,
14
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
 * See the License for the specific language governing permissions and
16
 * limitations under the License.
17
 */
18
package org.jreleaser.engine.upload;
19

20
import org.jreleaser.bundle.RB;
21
import org.jreleaser.extensions.api.workflow.WorkflowListenerException;
22
import org.jreleaser.model.JReleaserException;
23
import org.jreleaser.model.api.JReleaserCommand;
24
import org.jreleaser.model.api.hooks.ExecutionEvent;
25
import org.jreleaser.model.internal.JReleaserContext;
26
import org.jreleaser.model.internal.upload.Upload;
27
import org.jreleaser.model.internal.upload.Uploader;
28
import org.jreleaser.model.spi.upload.UploadException;
29

30
import java.util.List;
31
import java.util.Map;
32

33
import static java.util.stream.Collectors.toList;
34
import static org.jreleaser.model.internal.JReleaserSupport.supportedUploaders;
35

36
/**
37
 * @author Andres Almiray
38
 * @since 0.3.0
39
 */
40
public final class Uploaders {
41
    private Uploaders() {
42
        // noop
43
    }
44

45
    public static void upload(JReleaserContext context) {
46
        context.getLogger().info(RB.$("uploaders.header"));
1✔
47
        context.getLogger().increaseIndent();
1✔
48
        context.getLogger().setPrefix("upload");
1✔
49

50
        Upload upload = context.getModel().getUpload();
1✔
51
        if (!upload.isEnabled()) {
1✔
UNCOV
52
            context.getLogger().info(RB.$("uploaders.not.enabled"));
×
UNCOV
53
            context.getLogger().decreaseIndent();
×
UNCOV
54
            context.getLogger().restorePrefix();
×
UNCOV
55
            return;
×
56
        }
57

58
        try {
59
            doUpload(context, upload);
1✔
60
        } finally {
61
            context.getLogger().decreaseIndent();
1✔
62
            context.getLogger().restorePrefix();
1✔
63
        }
64
    }
1✔
65

66
    private static void doUpload(JReleaserContext context, Upload upload) {
67
        if (!context.getIncludedUploaderTypes().isEmpty()) {
1✔
68
            for (String uploaderType : context.getIncludedUploaderTypes()) {
×
69
                // check if the uploaderType is valid
70
                if (!supportedUploaders().contains(uploaderType)) {
×
71
                    context.getLogger().warn(RB.$("ERROR_unsupported_uploader", uploaderType));
×
72
                    continue;
×
73
                }
74

75
                Map<String, Uploader<?>> uploaders = upload.findUploadersByType(uploaderType);
×
76

77
                if (uploaders.isEmpty()) {
×
78
                    context.getLogger().info(RB.$("uploaders.no.match"), uploaderType);
×
79
                    return;
×
80
                }
81

82
                if (!context.getIncludedUploaderNames().isEmpty()) {
×
83
                    boolean uploaded = false;
×
84
                    for (String uploaderName : context.getIncludedUploaderNames()) {
×
85
                        if (!uploaders.containsKey(uploaderName)) {
×
86
                            context.getLogger().warn(RB.$("uploaders.uploader.not.configured"), uploaderType, uploaderName);
×
87
                            continue;
×
88
                        }
89

90
                        Uploader<?> uploader = uploaders.get(uploaderName);
×
91
                        if (!uploader.isEnabled()) {
×
92
                            context.getLogger().info(RB.$("uploaders.uploader.disabled"), uploaderType, uploaderName);
×
93
                            continue;
×
94
                        }
95

96
                        context.getLogger().info(RB.$("uploaders.upload.with"),
×
97
                            uploaderType,
98
                            uploaderName);
99
                        if (upload(context, uploader)) uploaded = true;
×
100
                    }
×
101

102
                    if (!uploaded) {
×
103
                        context.getLogger().info(RB.$("uploaders.not.triggered"));
×
104
                    }
105
                } else {
×
106
                    context.getLogger().info(RB.$("uploaders.upload.all.artifacts.with"), uploaderType);
×
107
                    boolean[] uploaded = new boolean[]{false};
×
108
                    uploaders.values().forEach(uploader -> {
×
109
                        if (upload(context, uploader)) uploaded[0] = true;
×
110
                    });
×
111

112
                    if (!uploaded[0]) {
×
113
                        context.getLogger().info(RB.$("uploaders.not.triggered"));
×
114
                    }
115
                }
116
            }
×
117
        } else if (!context.getIncludedUploaderNames().isEmpty()) {
1✔
118
            boolean[] uploaded = new boolean[]{false};
×
119
            for (String uploaderName : context.getIncludedUploaderNames()) {
×
120
                List<Uploader<?>> filteredUploaders = upload.findAllActiveUploaders().stream()
×
121
                    .filter(a -> uploaderName.equals(a.getName()))
×
122
                    .collect(toList());
×
123

124
                if (!filteredUploaders.isEmpty()) {
×
125
                    context.getLogger().info(RB.$("uploaders.upload.all.artifacts.to"), uploaderName);
×
126
                    filteredUploaders.forEach(uploader -> {
×
127
                        if (upload(context, uploader)) uploaded[0] = true;
×
128
                    });
×
129
                } else {
130
                    context.getLogger().warn(RB.$("uploaders.uploader.not.configured2"), uploaderName);
×
131
                }
132
            }
×
133

134
            if (!uploaded[0]) {
×
135
                context.getLogger().info(RB.$("uploaders.not.triggered"));
×
136
            }
137
        } else {
×
138
            boolean uploaded = false;
1✔
139
            context.getLogger().info(RB.$("uploaders.upload.all.artifacts"));
1✔
140
            for (Uploader<?> uploader : upload.findAllActiveUploaders()) {
1✔
141
                String uploaderType = uploader.getType();
1✔
142
                String uploaderName = uploader.getName();
1✔
143

144
                if (context.getExcludedUploaderTypes().contains(uploaderType) ||
1✔
145
                    context.getExcludedUploaderNames().contains(uploaderName)) {
1✔
146
                    context.getLogger().info(RB.$("uploaders.uploader.excluded"), uploaderType, uploaderName);
×
147
                    continue;
×
148
                }
149

150
                if (upload(context, uploader)) uploaded = true;
1✔
151
            }
1✔
152

153
            if (!uploaded) {
1✔
154
                context.getLogger().info(RB.$("uploaders.not.triggered"));
×
155
            }
156
        }
157
    }
1✔
158

159
    private static boolean upload(JReleaserContext context, Uploader<?> uploader) {
160
        try {
161
            context.getLogger().increaseIndent();
1✔
162
            context.getLogger().setPrefix(uploader.getType());
1✔
163
            fireUploadEvent(ExecutionEvent.before(JReleaserCommand.UPLOAD.toStep()), context, uploader);
1✔
164

165
            ProjectUploader projectUploader = createProjectUploader(context, uploader);
1✔
166
            boolean uploaded = projectUploader.upload();
1✔
167

168
            fireUploadEvent(ExecutionEvent.success(JReleaserCommand.UPLOAD.toStep()), context, uploader);
1✔
169
            return uploaded;
1✔
170
        } catch (UploadException e) {
×
171
            fireUploadEvent(ExecutionEvent.failure(JReleaserCommand.UPLOAD.toStep(), e), context, uploader);
×
172
            throw new JReleaserException(RB.$("ERROR_unexpected_error"), e);
×
173
        } finally {
174
            context.getLogger().restorePrefix();
1✔
175
            context.getLogger().decreaseIndent();
1✔
176
        }
177
    }
178

179
    private static ProjectUploader createProjectUploader(JReleaserContext context,
180
                                                         Uploader<?> uploader) {
181
        return ProjectUploader.builder()
1✔
182
            .context(context)
1✔
183
            .uploader(uploader)
1✔
184
            .build();
1✔
185
    }
186

187
    private static void fireUploadEvent(ExecutionEvent event, JReleaserContext context, Uploader<?> uploader) {
188
        if (!uploader.isEnabled()) return;
1✔
189

190
        try {
191
            context.fireUploadStepEvent(event, uploader.asImmutable());
1✔
192
        } catch (WorkflowListenerException e) {
×
193
            context.getLogger().error(RB.$("listener.failure", e.getListener().getClass().getName()));
×
194
            context.getLogger().trace(e);
×
195
            if (event.getType() != ExecutionEvent.Type.FAILURE && !e.getListener().isContinueOnError()) {
×
196
                if (e.getCause() instanceof RuntimeException) {
×
197
                    throw (RuntimeException) e.getCause();
×
198
                } else {
199
                    throw new JReleaserException(RB.$("ERROR_unexpected_error"), e.getCause());
×
200
                }
201
            }
202
        }
1✔
203
    }
1✔
204
}
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

© 2026 Coveralls, Inc