diff --git a/src/main/java/com/conveyal/gtfs/GTFS.java b/src/main/java/com/conveyal/gtfs/GTFS.java index aec965db5..5c85d9148 100644 --- a/src/main/java/com/conveyal/gtfs/GTFS.java +++ b/src/main/java/com/conveyal/gtfs/GTFS.java @@ -46,10 +46,9 @@ public abstract class GTFS { /** * Export a feed ID from the database to a zipped GTFS file in the specified export directory. */ - public static FeedLoadResult export (String feedId, String outFile, DataSource dataSource, boolean fromEditor) { - JdbcGtfsExporter exporter = new JdbcGtfsExporter(feedId, outFile, dataSource, fromEditor); - FeedLoadResult result = exporter.exportTables(); - return result; + public static FeedLoadResult export (String feedId, String outFile, DataSource dataSource, boolean fromEditor, boolean publishProprietaryFiles) { + JdbcGtfsExporter exporter = new JdbcGtfsExporter(feedId, outFile, dataSource, fromEditor, publishProprietaryFiles); + return exporter.exportTables(); } /** @@ -299,13 +298,16 @@ public static void main (String[] args) throws IOException { if (cmd.hasOption("export")) { String namespaceToExport = cmd.getOptionValue("export"); + boolean exportProprietaryFiles = (cmd.getOptionValue("exportProprietaryFiles") != null) + && Boolean.parseBoolean(cmd.getOptionValue("exportProprietaryFiles")); + String outFile = cmd.getOptionValue("outFile"); if (namespaceToExport == null && loadResult != null) { namespaceToExport = loadResult.uniqueIdentifier; } if (namespaceToExport != null) { LOG.info("Exporting feed with unique identifier {}", namespaceToExport); - FeedLoadResult exportResult = export(namespaceToExport, outFile, dataSource, true); + export(namespaceToExport, outFile, dataSource, true, exportProprietaryFiles); LOG.info("Done exporting."); } else { LOG.error("No feed to export. Specify one, or load a feed in the same command."); diff --git a/src/main/java/com/conveyal/gtfs/loader/JdbcGtfsExporter.java b/src/main/java/com/conveyal/gtfs/loader/JdbcGtfsExporter.java index b0e5d9666..3e219eba3 100644 --- a/src/main/java/com/conveyal/gtfs/loader/JdbcGtfsExporter.java +++ b/src/main/java/com/conveyal/gtfs/loader/JdbcGtfsExporter.java @@ -45,7 +45,7 @@ public class JdbcGtfsExporter { private final boolean fromEditor; /** If this is true will export tables prefixed with {@link Table#PROPRIETARY_FILE_PREFIX} **/ - private final boolean exportProprietaryFiles; + private final boolean publishProprietaryFiles; // These fields will be filled in once feed snapshot begins. private Connection connection; @@ -63,21 +63,17 @@ public class JdbcGtfsExporter { Table.TRIPS.fileName ); + public static final List proprietaryFileList = Lists.newArrayList( + String.format("%s%s", Table.PROPRIETARY_FILE_PREFIX, Table.PATTERNS.fileName) + ); - public JdbcGtfsExporter(String feedId, String outFile, DataSource dataSource, boolean fromEditor) { - this.feedIdToExport = feedId; - this.outFile = outFile; - this.dataSource = dataSource; - this.fromEditor = fromEditor; - this.exportProprietaryFiles = true; - } - public JdbcGtfsExporter(String feedId, String outFile, DataSource dataSource, boolean fromEditor, boolean exportProprietaryFiles) { + public JdbcGtfsExporter(String feedId, String outFile, DataSource dataSource, boolean fromEditor, boolean publishProprietaryFiles) { this.feedIdToExport = feedId; this.outFile = outFile; this.dataSource = dataSource; this.fromEditor = fromEditor; - this.exportProprietaryFiles = exportProprietaryFiles; + this.publishProprietaryFiles = publishProprietaryFiles; } /** @@ -254,9 +250,6 @@ public FeedLoadResult exportTables() { result.routes = export(Table.ROUTES, connection); } - if (exportProprietaryFiles) { - result.patterns = export(Table.PATTERNS, connection); - } // Only write shapes for "approved" routes using COPY TO with results of select query if (fromEditor) { // Generate filter SQL for shapes if exporting a feed/schema that represents an editor snapshot. @@ -334,6 +327,8 @@ public FeedLoadResult exportTables() { result.trips = export(Table.TRIPS, connection); } + exportProprietaryFiles(result); + zipOutputStream.close(); // Run clean up on the resulting zip file. cleanUpZipFile(); @@ -354,6 +349,15 @@ public FeedLoadResult exportTables() { return result; } + /** + * Export proprietary files, if they are required. + */ + private void exportProprietaryFiles(FeedLoadResult result) { + if (publishProprietaryFiles) { + result.patterns = export(Table.PATTERNS, connection); + } + } + /** * Removes any empty zip files from the final zip file unless they are required files. */ diff --git a/src/test/java/com/conveyal/gtfs/GTFSTest.java b/src/test/java/com/conveyal/gtfs/GTFSTest.java index 1aad4b97e..470711d0b 100644 --- a/src/test/java/com/conveyal/gtfs/GTFSTest.java +++ b/src/test/java/com/conveyal/gtfs/GTFSTest.java @@ -635,7 +635,7 @@ void canExportEmptyMandatoryFiles() { } // Confirm that the mandatory files are present in the zip file. - tempFile = exportGtfs(namespace, dataSource, false); + tempFile = exportGtfs(namespace, dataSource, false, true); ZipFile gtfsZipFile = new ZipFile(tempFile.getAbsolutePath()); for (String fileName : JdbcGtfsExporter.mandatoryFileList) { Assert.assertNotNull(gtfsZipFile.getEntry(fileName)); @@ -647,6 +647,33 @@ void canExportEmptyMandatoryFiles() { if (tempFile != null) tempFile.deleteOnExit(); } } + /** + * Load a feed and then export minus proprietary files. Confirm proprietary files are not present in export. + */ + @Test + void canOmitProprietaryFiles() { + String testDBName = TestUtils.generateNewDB(); + File tempFile = null; + try { + String zipFileName = TestUtils.zipFolderFiles("fake-agency", true); + String dbConnectionUrl = String.join("/", JDBC_URL, testDBName); + DataSource dataSource = TestUtils.createTestDataSource(dbConnectionUrl); + FeedLoadResult loadResult = GTFS.load(zipFileName, dataSource); + String namespace = loadResult.uniqueIdentifier; + + // Confirm that the proprietary files are not present in the zip file. + tempFile = exportGtfs(namespace, dataSource, false, false); + ZipFile gtfsZipFile = new ZipFile(tempFile.getAbsolutePath()); + for (String fileName : JdbcGtfsExporter.proprietaryFileList) { + Assert.assertNull(gtfsZipFile.getEntry(fileName)); + } + } catch (IOException e) { + LOG.error("An error occurred while attempting to test exporting of proprietary files.", e); + } finally { + TestUtils.dropDB(testDBName); + if (tempFile != null) tempFile.deleteOnExit(); + } + } /** * A helper method that will run GTFS#main with a certain zip file. @@ -693,7 +720,7 @@ private boolean runIntegrationTestOnZipFile( // Verify that exporting the feed (in non-editor mode) completes and data is outputted properly LOG.info("export GTFS from created namespace"); - File tempFile = exportGtfs(namespace, dataSource, false); + File tempFile = exportGtfs(namespace, dataSource, false, true); assertThatExportedGtfsMeetsExpectations(tempFile, persistenceExpectations, false); // Verify that making a snapshot from an existing feed database, then exporting that snapshot to a GTFS zip @@ -794,9 +821,14 @@ private void assertThatSnapshotIsErrorFree(SnapshotResult snapshotResult) { /** * Helper function to export a GTFS from the database to a temporary zip file. */ - private File exportGtfs(String namespace, DataSource dataSource, boolean fromEditor) throws IOException { +// private File exportGtfs(String namespace, DataSource dataSource, boolean fromEditor) throws IOException { +// File tempFile = File.createTempFile("snapshot", ".zip"); +// GTFS.export(namespace, tempFile.getAbsolutePath(), dataSource, fromEditor, false); +// return tempFile; +// } + private File exportGtfs(String namespace, DataSource dataSource, boolean fromEditor, boolean publishProprietaryFiles) throws IOException { File tempFile = File.createTempFile("snapshot", ".zip"); - GTFS.export(namespace, tempFile.getAbsolutePath(), dataSource, fromEditor); + GTFS.export(namespace, tempFile.getAbsolutePath(), dataSource, fromEditor, publishProprietaryFiles); return tempFile; } @@ -833,7 +865,7 @@ private boolean assertThatSnapshotIsSuccessful( true ); LOG.info("export GTFS from copied namespace"); - File tempFile = exportGtfs(copyResult.uniqueIdentifier, dataSource, true); + File tempFile = exportGtfs(copyResult.uniqueIdentifier, dataSource, true, true); assertThatExportedGtfsMeetsExpectations(tempFile, persistenceExpectations, true); } catch (IOException | SQLException e) { e.printStackTrace();