blob: 8fc4c347a3ccd817f20507fdb461d5fcf5417c71 [file] [log] [blame]
package org.apache.maven.index.reader;
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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.
*/
import java.io.File;
import java.io.IOException;
import java.io.PrintWriter;
import java.net.URL;
import java.util.Arrays;
import java.util.Date;
import java.util.Map;
import org.apache.maven.index.reader.Record.Type;
import org.junit.Ignore;
import org.junit.Test;
import static org.apache.maven.index.reader.TestUtils.expandFunction;
import static com.google.common.collect.Iterables.transform;
import static org.hamcrest.core.IsEqual.equalTo;
import static org.hamcrest.core.IsNot.not;
import static org.hamcrest.core.IsNull.nullValue;
import static org.junit.Assert.assertThat;
/**
* UT for {@link IndexReader}
*/
public class IndexReaderTest
extends TestSupport
{
@Test
public void simple() throws IOException {
final IndexReader indexReader = new IndexReader(
null,
testResourceHandler("simple")
);
try {
assertThat(indexReader.getIndexId(), equalTo("apache-snapshots-local"));
assertThat(indexReader.getPublishedTimestamp().getTime(), equalTo(1243533418015L));
assertThat(indexReader.isIncremental(), equalTo(false));
assertThat(indexReader.getChunkNames(), equalTo(Arrays.asList("nexus-maven-repository-index.gz")));
int chunks = 0;
int records = 0;
for (ChunkReader chunkReader : indexReader) {
chunks++;
assertThat(chunkReader.getName(), equalTo("nexus-maven-repository-index.gz"));
assertThat(chunkReader.getVersion(), equalTo(1));
assertThat(chunkReader.getTimestamp().getTime(), equalTo(1243533418015L));
for (Record record : transform(chunkReader, expandFunction)) {
records++;
}
}
assertThat(chunks, equalTo(1));
assertThat(records, equalTo(5));
}
finally {
indexReader.close();
}
}
@Test
public void simpleWithLocal() throws IOException {
WritableResourceHandler writableResourceHandler = createWritableResourceHandler();
final IndexReader indexReader = new IndexReader(
writableResourceHandler,
testResourceHandler("simple")
);
try {
assertThat(indexReader.getIndexId(), equalTo("apache-snapshots-local"));
assertThat(indexReader.getPublishedTimestamp().getTime(), equalTo(1243533418015L));
assertThat(indexReader.isIncremental(), equalTo(false));
assertThat(indexReader.getChunkNames(), equalTo(Arrays.asList("nexus-maven-repository-index.gz")));
int chunks = 0;
int records = 0;
for (ChunkReader chunkReader : indexReader) {
chunks++;
assertThat(chunkReader.getName(), equalTo("nexus-maven-repository-index.gz"));
assertThat(chunkReader.getVersion(), equalTo(1));
assertThat(chunkReader.getTimestamp().getTime(), equalTo(1243533418015L));
for (Record record : transform(chunkReader, expandFunction)) {
records++;
}
}
assertThat(chunks, equalTo(1));
assertThat(records, equalTo(5));
}
finally {
indexReader.close();
}
assertThat(writableResourceHandler.locate("nexus-maven-repository-index.properties").read(), not(nullValue()));
}
@Test
public void roundtrip() throws IOException {
WritableResourceHandler writableResourceHandler = createWritableResourceHandler();
Date published;
{
final IndexReader indexReader = new IndexReader(
null,
testResourceHandler("simple")
);
final IndexWriter indexWriter = new IndexWriter(
writableResourceHandler,
indexReader.getIndexId(),
false
);
try {
for (ChunkReader chunkReader : indexReader) {
indexWriter.writeChunk(chunkReader.iterator());
}
}
finally {
indexWriter.close();
published = indexWriter.getPublishedTimestamp();
indexReader.close();
}
}
final IndexReader indexReader = new IndexReader(
null,
writableResourceHandler
);
try {
assertThat(indexReader.getIndexId(), equalTo("apache-snapshots-local"));
assertThat(indexReader.getPublishedTimestamp().getTime(), equalTo(published.getTime()));
assertThat(indexReader.isIncremental(), equalTo(false));
assertThat(indexReader.getChunkNames(), equalTo(Arrays.asList("nexus-maven-repository-index.gz")));
int chunks = 0;
int records = 0;
for (ChunkReader chunkReader : indexReader) {
chunks++;
assertThat(chunkReader.getName(), equalTo("nexus-maven-repository-index.gz"));
assertThat(chunkReader.getVersion(), equalTo(1));
// assertThat(chunkReader.getTimestamp().getTime(), equalTo(1243533418015L));
for (Record record : transform(chunkReader, expandFunction)) {
records++;
}
}
assertThat(chunks, equalTo(1));
assertThat(records, equalTo(5));
}
finally {
indexReader.close();
}
}
/**
* This UT is here for demonstration purposes only. Bashing Central is not something you want to do, and risk your
* IP address being banned. You were warned!
*/
@Test
@Ignore("For eyes only")
public void central() throws Exception {
// local index location, against which we perform incremental updates
final File indexDir = createTempDirectory();
// cache of remote, to not rely on HTTP transport possible failures, or, to detect them early
final File cacheDir = createTempDirectory();
final PrintWriter writer = new PrintWriter(System.out, true);
final WritableResourceHandler local = new DirectoryResourceHandler(indexDir);
final CachingResourceHandler remote = new CachingResourceHandler(
new DirectoryResourceHandler(cacheDir),
new HttpResourceHandler(new URL("http://repo1.maven.org/maven2/.index/"))
);
final IndexReader indexReader = new IndexReader(local, remote);
try {
writer.println("indexRepoId=" + indexReader.getIndexId());
writer.println("indexLastPublished=" + indexReader.getPublishedTimestamp());
writer.println("isIncremental=" + indexReader.isIncremental());
writer.println("indexRequiredChunkNames=" + indexReader.getChunkNames());
for (ChunkReader chunkReader : indexReader) {
writer.println("chunkName=" + chunkReader.getName());
writer.println("chunkVersion=" + chunkReader.getVersion());
writer.println("chunkPublished=" + chunkReader.getTimestamp());
writer.println("Chunk stats:");
Map<Type, Integer> stats = countRecordsByType(chunkReader);
for (Map.Entry<Type, Integer> entry : stats.entrySet()) {
writer.println(entry.getKey() + " = " + entry.getValue());
}
writer.println("= = = = = =");
}
}
finally {
indexReader.close();
remote.close();
local.close();
}
}
}