Skip to content

Commit

Permalink
chore: provide test to make sure overriding classloader works
Browse files Browse the repository at this point in the history
  • Loading branch information
simschla committed Feb 20, 2025
1 parent 88d3c31 commit 8ee1dfe
Showing 1 changed file with 107 additions and 0 deletions.
107 changes: 107 additions & 0 deletions lib/src/test/java/com/diffplug/spotless/JarStateTest.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,107 @@
/*
* Copyright 2025 DiffPlug
*
* 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 com.diffplug.spotless;

import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.net.URLClassLoader;
import java.nio.file.Files;
import java.util.stream.Collectors;

import org.assertj.core.api.SoftAssertions;
import org.junit.jupiter.api.AfterEach;
import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.io.TempDir;

class JarStateTest {

@TempDir
java.nio.file.Path tempDir;

File a;

File b;

Provisioner provisioner = (withTransitives, deps) -> deps.stream().map(name -> name.equals("a") ? a : b).collect(Collectors.toSet());

@BeforeEach
void setUp() throws IOException {
a = Files.createTempFile(tempDir, "a", ".class").toFile();
Files.writeString(a.toPath(), "a");
b = Files.createTempFile(tempDir, "b", ".class").toFile();
Files.writeString(b.toPath(), "b");
}

@AfterEach
void tearDown() {
JarState.setForcedClassLoader(null);
}

@Test
void itCreatesClassloaderWhenForcedClassLoaderNotSet() throws IOException {
JarState state1 = JarState.from(a.getName(), provisioner);
JarState state2 = JarState.from(b.getName(), provisioner);

SoftAssertions.assertSoftly(softly -> {
softly.assertThat(state1.getClassLoader()).isNotNull();
softly.assertThat(state2.getClassLoader()).isNotNull();
});
}

@Test
void itReturnsForcedClassloaderIfSetNoMatterIfSetBeforeOrAfterCreation() throws IOException {
JarState stateA = JarState.from(a.getName(), provisioner);
ClassLoader forcedClassLoader = new URLClassLoader(new java.net.URL[0]);
JarState.setForcedClassLoader(forcedClassLoader);
JarState stateB = JarState.from(b.getName(), provisioner);

SoftAssertions.assertSoftly(softly -> {
softly.assertThat(stateA.getClassLoader()).isSameAs(forcedClassLoader);
softly.assertThat(stateB.getClassLoader()).isSameAs(forcedClassLoader);
});
}

@Test
void itReturnsForcedClassloaderEvenWhenRountripSerialized() throws IOException, ClassNotFoundException {
JarState stateA = JarState.from(a.getName(), provisioner);
ClassLoader forcedClassLoader = new URLClassLoader(new java.net.URL[0]);
JarState.setForcedClassLoader(forcedClassLoader);
JarState stateB = JarState.from(b.getName(), provisioner);

JarState stateARoundtripSerialized = roundtripSerialize(stateA);
JarState stateBRoundtripSerialized = roundtripSerialize(stateB);

SoftAssertions.assertSoftly(softly -> {
softly.assertThat(stateARoundtripSerialized.getClassLoader()).isSameAs(forcedClassLoader);
softly.assertThat(stateBRoundtripSerialized.getClassLoader()).isSameAs(forcedClassLoader);
});
}

private JarState roundtripSerialize(JarState state) throws IOException, ClassNotFoundException {
ByteArrayOutputStream outputStream = new ByteArrayOutputStream();
try (ObjectOutputStream oOut = new ObjectOutputStream(outputStream)) {
oOut.writeObject(state);
}
try (ObjectInputStream oIn = new ObjectInputStream(new java.io.ByteArrayInputStream(outputStream.toByteArray()))) {
return (JarState) oIn.readObject();
}
}

}

0 comments on commit 8ee1dfe

Please sign in to comment.