Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Expose exceptions in DumpProcessingController #526

Open
wants to merge 3 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 2 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -374,7 +374,8 @@ public Sites getSitesInformation() throws IOException {
* @see DumpProcessingController#processDump(MwDumpFile)
* @see DumpProcessingController#getMostRecentDump(DumpContentType)
*/
public void processAllRecentRevisionDumps() {
public void processAllRecentRevisionDumps()
throws IOException, FileAlreadyExistsException {
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

FileAlreadyExistsException is a sub class of IOException (same in other places)

Copy link
Member Author

@wetneb wetneb Mar 24, 2021

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Perhaps there is still a case for including both of them explicitly in the signature, because the caller might want to handle them differently?

WmfDumpFileManager wmfDumpFileManager = getWmfDumpFileManager();
if (wmfDumpFileManager == null) {
return;
Expand Down Expand Up @@ -403,7 +404,8 @@ public void processAllRecentRevisionDumps() {
* in WDTK 0.5
*/
@Deprecated
public void processMostRecentDailyDump() {
public void processMostRecentDailyDump()
throws IOException, FileAlreadyExistsException {
processDump(getMostRecentDump(DumpContentType.JSON));
}

Expand All @@ -417,7 +419,8 @@ public void processMostRecentDailyDump() {
*
* @see DumpProcessingController#processAllRecentRevisionDumps()
*/
public void processMostRecentMainDump() {
public void processMostRecentMainDump()
throws IOException, FileAlreadyExistsException {
DumpContentType dumpContentType;
if (this.preferCurrent) {
dumpContentType = DumpContentType.CURRENT;
Expand All @@ -438,7 +441,8 @@ public void processMostRecentMainDump() {
*
* @see DumpProcessingController#processAllRecentRevisionDumps()
*/
public void processMostRecentJsonDump() {
public void processMostRecentJsonDump()
throws IOException, FileAlreadyExistsException {
processDump(getMostRecentDump(DumpContentType.JSON));
}

Expand All @@ -453,7 +457,8 @@ public void processMostRecentJsonDump() {
* @param dumpFile
* the dump to process
*/
public void processDump(MwDumpFile dumpFile) {
public void processDump(MwDumpFile dumpFile)
throws IOException, FileAlreadyExistsException {
if (dumpFile == null) {
return;
}
Expand Down Expand Up @@ -495,7 +500,8 @@ public void processDump(MwDumpFile dumpFile) {
*/
@Deprecated
public void processMostRecentDump(DumpContentType dumpContentType,
MwDumpFileProcessor dumpFileProcessor) {
MwDumpFileProcessor dumpFileProcessor)
throws IOException, FileAlreadyExistsException {
MwDumpFile dumpFile = getMostRecentDump(dumpContentType);
if (dumpFile != null) {
processDumpFile(dumpFile, dumpFileProcessor);
Expand Down Expand Up @@ -536,18 +542,23 @@ public MwDumpFile getMostRecentDump(DumpContentType dumpContentType) {
* the dump file processor to use
*/
void processDumpFile(MwDumpFile dumpFile,
MwDumpFileProcessor dumpFileProcessor) {
MwDumpFileProcessor dumpFileProcessor)
throws IOException, FileAlreadyExistsException {
try (InputStream inputStream = dumpFile.getDumpFileStream()) {
dumpFileProcessor.processDumpFileContents(inputStream, dumpFile);
} catch (FileAlreadyExistsException e) {
logger.error("Dump file "
String errorMessage = "Dump file "
+ dumpFile.toString()
+ " could not be processed since file "
+ e.getFile()
+ " already exists. Try deleting the file or dumpfile directory to attempt a new download.");
+ " already exists. Try deleting the file or dumpfile directory to attempt a new download.";
logger.error(errorMessage);
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I am not sure the logging is still useful now that we raise the exception again.

throw new FileAlreadyExistsException(errorMessage);
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Would be nice to give to the constructor the file names to allow getFile() to be used by the caller. C.f. doc

} catch (IOException e) {
logger.error("Dump file " + dumpFile.toString()
+ " could not be processed: " + e.toString());
String errorMessage = "Dump file " + dumpFile.toString()
+ " could not be processed: " + e.toString();
logger.error(errorMessage);
throw new IOException(errorMessage);
}
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -259,7 +259,7 @@ public int compare(
* which dump file to use and whether to run in offline mode, modify the
* settings in {@link ExampleHelpers}.
*/
public static void main(String[] args) {
public static void main(String[] args) throws IOException {
ExampleHelpers.configureLogging();
ClassPropertyUsageAnalyzer.printDocumentation();

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -96,7 +96,7 @@ static class UsageStatistics {
*
* @param args
*/
public static void main(String[] args) {
public static void main(String[] args) throws IOException {
ExampleHelpers.configureLogging();
EntityStatisticsProcessor.printDocumentation();

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -117,7 +117,7 @@ public static void configureLogging() {
* the object to use for processing entities in this dump
*/
public static void processEntitiesFromWikidataDump(
EntityDocumentProcessor entityDocumentProcessor) {
EntityDocumentProcessor entityDocumentProcessor) throws IOException {

// Controller object for processing dumps:
DumpProcessingController dumpProcessingController = new DumpProcessingController(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -124,7 +124,7 @@ public int compare(SiteRecord o1, SiteRecord o2) {
* results to a file. To change which dump file to use and whether to run in
* offline mode, modify the settings in {@link ExampleHelpers}.
*/
public static void main(String[] args) {
public static void main(String[] args) throws IOException {
ExampleHelpers.configureLogging();
GenderRatioProcessor.printDocumentation();

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -55,7 +55,7 @@ public class LifeExpectancyProcessor implements EntityDocumentProcessor {
* offline mode, modify the settings in {@link ExampleHelpers}.
*
*/
public static void main(String[] args) {
public static void main(String[] args) throws IOException {
ExampleHelpers.configureLogging();
LifeExpectancyProcessor.printDocumentation();

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,7 @@ public class LocalDumpFileExample {
*/
private final static String DUMP_FILE = "./src/resources/sample-dump-20150815.json.gz";

public static void main(String[] args) {
public static void main(String[] args) throws IOException {
ExampleHelpers.configureLogging();
LocalDumpFileExample.printDocumentation();

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,8 @@
* #L%
*/

import java.io.IOException;

import org.wikidata.wdtk.datamodel.interfaces.EntityDocumentProcessor;
import org.wikidata.wdtk.dumpfiles.DumpProcessingController;
import org.wikidata.wdtk.dumpfiles.MwRevision;
Expand All @@ -41,7 +43,7 @@
*/
public class TutorialExample {

public static void main(String[] args) {
public static void main(String[] args) throws IOException {
ExampleHelpers.configureLogging();

// Controller object for processing dumps:
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -103,7 +103,7 @@ public class WorldMapProcessor implements EntityDocumentProcessor {
*
* @param args
*/
public static void main(String[] args) {
public static void main(String[] args) throws IOException {
ExampleHelpers.configureLogging();
WorldMapProcessor.printDocumentation();

Expand Down