Skip to content

Commit

Permalink
[MODULES-195] Avoid infinite loop when iterating over modules.
Browse files Browse the repository at this point in the history
  • Loading branch information
metlos committed Jul 23, 2014
1 parent 56458db commit 271dc35
Show file tree
Hide file tree
Showing 2 changed files with 57 additions and 6 deletions.
13 changes: 7 additions & 6 deletions src/main/java/org/jboss/modules/ModuleLoader.java
Original file line number Diff line number Diff line change
Expand Up @@ -264,14 +264,15 @@ public boolean hasNext() {
}
final ModuleFinder finder = finders[idx++];
if (finder instanceof IterableModuleFinder) {
final Iterator<ModuleIdentifier> iterator = ((IterableModuleFinder) finder).iterateModules(baseIdentifier, recursive);
if (iterator.hasNext()) {
nested = iterator;
return true;
}
nested = ((IterableModuleFinder) finder).iterateModules(baseIdentifier, recursive);
}
}
if (! nested.hasNext()) nested = null;

if (! nested.hasNext()) {
nested = null;
} else {
return true;
}
}
}

Expand Down
50 changes: 50 additions & 0 deletions src/test/java/org/jboss/modules/ModuleIteratorTest.java
Original file line number Diff line number Diff line change
Expand Up @@ -67,6 +67,56 @@ public void testMetaInfServicesIterator() throws Exception {
Assert.assertFalse("No other resource", itres.hasNext());
}

@Test
public void testIterateModules() throws Exception {
IterableModuleFinder fakeFinder = new IterableModuleFinder() {
private ModuleIdentifier[] modules = { ModuleIdentifier.create("a"), ModuleIdentifier.create("b")};

@Override
public Iterator<ModuleIdentifier> iterateModules(ModuleIdentifier baseIdentifier, boolean recursive) {
return new Iterator<ModuleIdentifier>() {
private int pos = 0;

@Override
public boolean hasNext() {
return pos < modules.length;
}

@Override
public ModuleIdentifier next() {
return modules[pos++];
}

@Override
public void remove() {
throw new UnsupportedOperationException();
}
};
}

@Override
public ModuleSpec findModule(ModuleIdentifier identifier, ModuleLoader delegateLoader)
throws ModuleLoadException {
for (ModuleIdentifier m : modules) {
if (m.equals(identifier)) {
return ModuleSpec.build(m).create();
}
}
return null;
}
};

ModuleLoader loader = new ModuleLoader(new ModuleFinder[]{fakeFinder});

Iterator<ModuleIdentifier> it = loader.iterateModules(null, true);
int count = 0;
while (it.hasNext()) {
it.next();
count++;
}

Assert.assertEquals(2, count);
}

private JarFile toJarFile(JavaArchive archive) throws IOException {
ZipExporter exporter = archive.as(ZipExporter.class);
Expand Down

0 comments on commit 271dc35

Please sign in to comment.