update OpenRefine
This commit is contained in:
parent
b633a4c51e
commit
b37b4153bf
18
OpenRefine/.github/dependabot.yml
vendored
18
OpenRefine/.github/dependabot.yml
vendored
@ -14,16 +14,30 @@ updates:
|
||||
versions:
|
||||
- "> 1.4.12"
|
||||
- "< 2"
|
||||
|
||||
# Same, on 4.0 branch
|
||||
- package-ecosystem: maven
|
||||
directory: "/"
|
||||
schedule:
|
||||
interval: daily
|
||||
open-pull-requests-limit: 10
|
||||
ignore:
|
||||
- dependency-name: com.thoughtworks.xstream:xstream
|
||||
versions:
|
||||
- "> 1.4.12"
|
||||
- "< 2"
|
||||
target-branch: 4.0
|
||||
|
||||
# For documentation website
|
||||
- package-ecosystem: "npm" # For Yarn
|
||||
directory: "docs/"
|
||||
schedule:
|
||||
interval: "daily"
|
||||
interval: "monthly"
|
||||
# For github actions
|
||||
- package-ecosystem: "github-actions"
|
||||
directory: "/"
|
||||
schedule:
|
||||
interval: "daily"
|
||||
interval: "monthly"
|
||||
# For cypress test_suite
|
||||
- package-ecosystem: "npm"
|
||||
directory: "main/tests/cypress"
|
||||
|
@ -14,7 +14,7 @@ jobs:
|
||||
server_tests:
|
||||
strategy:
|
||||
matrix:
|
||||
java: [ 11, 14 ]
|
||||
java: [ 11, 17 ]
|
||||
|
||||
runs-on: ubuntu-latest
|
||||
|
||||
@ -64,6 +64,11 @@ jobs:
|
||||
distribution: 'adopt'
|
||||
java-version: ${{ matrix.java }}
|
||||
|
||||
- name: Check Java linting
|
||||
id: java_linting
|
||||
run: |
|
||||
mvn formatter:validate
|
||||
|
||||
- name: Configure connections to databases
|
||||
id: configure_db_connections
|
||||
run: cat extensions/database/tests/conf/github_actions_tests.xml | sed -e "s/MYSQL_PORT/${{ job.services.mysql.ports[3306] }}/g" | sed -e "s/POSTGRES_PORT/${{ job.services.postgres.ports[5432] }}/g" > extensions/database/tests/conf/tests.xml
|
||||
|
@ -1,78 +0,0 @@
|
||||
This file lists the contributors to OpenRefine.
|
||||
|
||||
EMERITUS CREATORS
|
||||
---------------------
|
||||
No longer active but honored for bringing OpenRefine to life.
|
||||
- David Huynh
|
||||
- Stefano Mazzocchi
|
||||
|
||||
EMERITUS CONTRIBUTORS
|
||||
---------------------
|
||||
No longer active but honored here for their previous contributions
|
||||
|
||||
- Vishal Talwar
|
||||
- Jeff Fry
|
||||
- Will Moffat
|
||||
- James Home
|
||||
- Heather Campbell
|
||||
|
||||
CURRENT CONTRIBUTORS
|
||||
--------------------
|
||||
|
||||
See up to date list at https://github.com/OpenRefine/OpenRefine/graphs/contributors
|
||||
|
||||
- Iain Sproat
|
||||
- Tom Morris
|
||||
- Thad Guidry
|
||||
- Martin Magdinier
|
||||
- Paul Makepeace
|
||||
- Tomaž Šolc
|
||||
- Gabriel Sjoberg
|
||||
- Rod Salazar
|
||||
- pxb
|
||||
- Qi
|
||||
- Antonin Delpeuch
|
||||
- Owen Stephens
|
||||
- Ettore Rizza
|
||||
- Fabio Tacchelli
|
||||
- noamoss
|
||||
- ROMitat
|
||||
- Jesus M. Castagnetto
|
||||
- Pablo Moyano
|
||||
- David Leoni
|
||||
- Cora Johnson-Roberson
|
||||
- Pei Long Hui
|
||||
- Rudy Alvarez
|
||||
- Mateja Verlic Bruncic
|
||||
- nestorjal
|
||||
- Alexey Medvetsky
|
||||
- Remi Rampin
|
||||
- lispc
|
||||
- Bob Harper
|
||||
- Felix Lohmeier
|
||||
- Shixiong Zhu
|
||||
- Ankit Sardesai
|
||||
- Scott Wiedemann
|
||||
- Ryo Yamazaki
|
||||
- Ralf Claussnitzer
|
||||
- Charles Pritchard
|
||||
- Maxim Galushka
|
||||
- Evelyn Mitchell
|
||||
- Andreas Kohn
|
||||
- Honza
|
||||
- Ram Ezrach
|
||||
- Daniel Berthereau
|
||||
- Gideon Thomas
|
||||
- José Vitor Hisse
|
||||
- Vitor Baptista
|
||||
- Joe Wicentowski
|
||||
- mpc9000
|
||||
- Dan Michael O.
|
||||
- Adi Eyal
|
||||
- Shrubhra Sharma
|
||||
- Fadi Maali
|
||||
- Aubrey Mcfato
|
||||
- Matthias Findeisen
|
||||
- Mathieu Saby
|
||||
- Allan Nordhøy
|
||||
- Tony Opara
|
@ -1,284 +0,0 @@
|
||||
2.6 Release (TBD) - First release as OpenRefine - Maintenance release
|
||||
|
||||
Features:
|
||||
|
||||
- Issue 144: Use subdirectory for archives (tar, zip)
|
||||
- Issue 467: Provide feedback to user on JVM heap memory usage
|
||||
- Issue 524: Shorten name of anonymous JSON nodes in column names
|
||||
|
||||
Bugs fixed:
|
||||
|
||||
- Issue 154: Can't import RDF/XML Data
|
||||
- Issue 226: Load into freebase: date objects are not converted into proper freebase dates
|
||||
- Issue 361: Headless operation on OS X leaves Dock icon bouncing
|
||||
- Issue 390: Latest POI fixes some import issues
|
||||
- Issue 432: cross() failing
|
||||
- Issue 436: Google refine don't start on debian squeeze
|
||||
- Issue 490: Unable to guess filetype is CSV when importing a simple CSV file
|
||||
- Issue 496: google-refine-2.5-rc2-r2379 failed to start if using refine.ini
|
||||
- Issue 515: "Open Project" page shows negative interval for "Last Modified"
|
||||
- Issue 517: Combin() function does not work as intended
|
||||
- Issue 521: Machine readable string (/type/rawstring) missing
|
||||
- Issue 523: Return all available HTTP error information on when Fetch URL fails
|
||||
- Issue 535: Refine fails to import Excel 2010 XLSX file with null hyperlinks
|
||||
- Issue 537: ToNumber should try to convert to integer first
|
||||
- Issue 541: Can't constrain a Freebase key query when using add column
|
||||
- Issue 542: ToDate should work on integers
|
||||
- Issue 543: Project creation from URL can't handle gzip Content-Encoding
|
||||
- Issue 544: FileNotFound exception when importing archive from URL
|
||||
- Issue 548: escape(value, encoding) returns "null" for non-string values
|
||||
- Issue 551: MQL preview missing "insert" clause
|
||||
- Issue 553: Upload Error - Not a directory
|
||||
- Issue 554: Format guesser ranking isn't working correctly in some cases
|
||||
- Issue 558: 'refine windows_dist' does not work on MacOS Lion
|
||||
- Issue 559: Deadlock between autosave thread and history code
|
||||
- Issue 578: json import on create project deletes useful blank data from arrays
|
||||
- Issue 586: Only one parse date format is attempted from list in toDate(format1,format2)
|
||||
- Issue 594: Date diff function doesn't work for two Calendar objects
|
||||
- Issue 596: JSON importer should not deserialize nulls as the string "null"
|
||||
- Issue 597: Deselect all button on Custom Tabular Exporter dialog doesn't work
|
||||
- Issue 599: RDF/XML parser preview not wired up
|
||||
- Issue 601: Allow selection of root element on JSON import
|
||||
- Issue 604: The common transform “Trim leading and trailing whitespace” doesn’t trim non-breaking spaces
|
||||
|
||||
|
||||
2.5 Release (December 11, 2011)
|
||||
|
||||
Major changes:
|
||||
- Entirely new importer architecture and user interface for Create Project
|
||||
- New import/export formats: Google Fusion Tables, OpenOffice Calc,
|
||||
and fixed width (import only)
|
||||
|
||||
Features:
|
||||
|
||||
- Issue 131: Read multiple files in a directory
|
||||
- Issue 179: Progress feedback during upload
|
||||
- Issue 260: XML Importer silently fails if file doesn't meet its criteria
|
||||
- Issue 279: Add support for reading from non-public Google Spreadsheets docs
|
||||
- Issue 280: Spreadsheet/table importers should allow selection of sheet/table to import
|
||||
- Issue 281: Add sheet selection support to Google Spreadsheet importer
|
||||
- Issue 31: Maximum number of facet values should be configurable.
|
||||
- Issue 38: Fix the table header so that it's always visible when scrolling a long page
|
||||
- Issue 433: Usability: use HTML <label> (e.g., for checkboxes
|
||||
- Issue 447: Extend toTitlecase() function with support for char[] delimiters in Apache WordUtils
|
||||
- Issue 452: Importing using Clipboard function does not guess structure correctly for XML or JSON
|
||||
- Issue 483: Project custom metadata while importing
|
||||
- Issue 504: Allow "sort" keyword in constraint subquery for "Add from Freebase"
|
||||
- Issue 84: Add a cut and paste textbox importer
|
||||
- Issue 85: Fixed width column importer
|
||||
- Issue 88: Improve operation history robustness by fixing Json.
|
||||
- Issue 92: Add Columns From Freebase dialog should support constraints
|
||||
- Issue 97: Exporting CSV should allow for optional columns
|
||||
|
||||
Bugs fixed:
|
||||
|
||||
- Issue 149: rows button stays strike-through when clicking on it
|
||||
- Issue 229: 'Ignore lines on import' bug when import from URL?
|
||||
- Issue 232: Stray characters before <?xml> (including blank lines) causes XML import to fail
|
||||
- Issue 233: 404 Error upon Launch
|
||||
- Issue 313: Excel export loses date cell format
|
||||
- Issue 314: Reconciliation (Freebase) of accented characters doesn't work
|
||||
- Issue 330: On Project creation - Unchecked Split Columns Box still splits by comma
|
||||
- Issue 366: Error when using Add column from Freebase on restored project
|
||||
- Issue 375: Importing data from Google spreadsheet via visualisation API query
|
||||
- Issue 378: Transform involving NaN causes crash
|
||||
- Issue 383: Updating Preview hangs on 2.5 branch when checking Load at most...
|
||||
- Issue 410: Convert line-endings to DOS format
|
||||
- Issue 419: Values with Characters like é split across several lines
|
||||
- Issue 424: Duplicate column names don't allow user to recover
|
||||
- Issue 426: filter with custom facet adds zero lines choice
|
||||
- Issue 428: Excel import sometimes drops last row of data
|
||||
- Issue 430: Timeline Facet not working
|
||||
- Issue 435: refine sh script only checks for java 1.6, not > 1.6
|
||||
- Issue 440: Fetch URLs aborts while saving/loading/computing facets
|
||||
- Issue 441: onError - "keep-original" / "store-blank" working oddly for value.toDate()
|
||||
- Issue 442: Two column transforms to date on the same column turns the cells blank
|
||||
- Issue 449: Uncaught exception from Excel importer
|
||||
- Issue 450: Parse error uploading to Fusion Table
|
||||
- Issue 454: Reselect Files after Configuring Parsing Options does not allow Select
|
||||
- Issue 459: Undefined error with some CSV files (incorrectly detected as EXCEL)
|
||||
- Issue 462: Don't trim whitespace in Excel importer
|
||||
- Issue 465: Data text file with extension .dta within a .ZIP is not automatically extracted
|
||||
- Issue 473: Cancel button doesn't work during project creation
|
||||
- Issue 474: XML importer ignores record limit
|
||||
- Issue 475: New Importer does not accept special separator characters completely such as Unicode chars
|
||||
- Issue 477: Implement or remove the line separator option
|
||||
- Issue 487: Transform -> To Date doesn't support ISO 8601 date parsing
|
||||
- Issue 488: ISO 8601 dates not supported in cell editing - cell-ui.js
|
||||
- Issue 489: Custom Exporter no longer behaves as expected with line & field separators
|
||||
- Issue 491: Importing Excel files - blank columns and time formatting
|
||||
- Issue 492: Table header cells misaligning with table cells
|
||||
- Issue 502: Fetch URLs does not return the exact HTTP payload, like Create Project from URLs does.
|
||||
- Issue 513: No more Json Tokens in stream ERROR
|
||||
|
||||
|
||||
2.1 Release (July 10, 2011) - Maintenance release
|
||||
|
||||
Features:
|
||||
|
||||
- Issue 157: Google Spreadsheet import/export plugin integrated
|
||||
- Issue 220: HTML parsing functions added to GREL (using Jsoup)
|
||||
- Issue 222: Added the ability to save favorite transforms
|
||||
- Issue 224: added ABS math function
|
||||
- Issue 349: Clustering not finding duplicates when facet is showing groupings
|
||||
- Issue 399: Added Cologne Phonetic clustering for German names
|
||||
|
||||
Bugs fixed:
|
||||
|
||||
- Issue 102: Process-Panel div sometimes disappears in Google Chrome
|
||||
- Issue 107: Reconciliation options not showing international characters correctly
|
||||
- Issue 143: Windows refine.bat file gives NoClassDefFoundError
|
||||
- Issue 163: Refine doesn't retain the characters for flat or sharp
|
||||
- Issue 172: inconsistencies in encoding guessing during load
|
||||
- Issue 184: Support formatting dates into strings
|
||||
- Issue 185: same reconciliation candidate for two cells seems to be overridden
|
||||
- Issue 187: Linux start instruction incorrect
|
||||
- Issue 188: ArrayIndexOutOfBoundsException when importing excel file
|
||||
- Issue 196: failure and error dialog attempting to remove columns
|
||||
- Issue 197: New project was modified "0 years ago"
|
||||
- Issue 202: Sort text with accents
|
||||
- Issue 203: Please add TextPipe to Related Software page
|
||||
- Issue 227: Documentation states extensions are mounted at /extensions, but they are really mounted at /extension.
|
||||
- Issue 228: Import .zip archive fails
|
||||
- Issue 237: reinterpret() no longer seems to work as expected
|
||||
- Issue 258: JAVA_HOME ignored if "which java" returns nonzero
|
||||
- Issue 262: Refine does not start
|
||||
- Issue 263: & symbol being parsed in url's in xml
|
||||
- Issue 276: strange character while create new project with a chinese project name
|
||||
- Issue 294: Exporting date type column to TSV/CSV shows java debugging information instead of value
|
||||
- Issue 295: Binaries under 'root' user on *nix
|
||||
- Issue 304: CsvExporter tests fail after commit for issue 294
|
||||
- Issue 311: "Ignore" and "Skip" fields in the "Create a New Project" form have the same input[name]
|
||||
- Issue 312: toString(date_val, 'yyyy-MM-dd') doesn't seem to work
|
||||
- Issue 325: Refine cannot load data from URL when run behind Proxy Server
|
||||
- Issue 328: Don't retry failed key-based reconciliations
|
||||
- Issue 334: Fusion Tables CSV import produces NullPointerException
|
||||
- Issue 351: Error 500 STREAM on Excel export
|
||||
- Issue 355: Broken images for SchemaAlignment page
|
||||
- Issue 358: org.json.JSONException: JSON does not allow non-finite numbers.
|
||||
- Issue 364: Build is broken
|
||||
- Issue 374: Problems with date functions INC
|
||||
- Issue 391: Patch to refine.{bat,ini}
|
||||
- Issue 401: Error in exception handling for ExportRows command
|
||||
- Issue 404: Intermittent charset detection failure
|
||||
- Issue 415: Evaluation precedence wrong for arithmetic expressions
|
||||
- Issue 61: multiple rows per column from 1 xml element
|
||||
|
||||
|
||||
2.0 Release (November 10, 2010 - first release as Google Refine)
|
||||
|
||||
Major Changes:
|
||||
- New extension architecture.
|
||||
- Generalized reconciliation framework that allows plugging in standard reconciliation services.
|
||||
- Support for QA on data loads into Freebase.
|
||||
- Timeline Facet (Issue 40 and 95)
|
||||
|
||||
Features:
|
||||
- New commands:
|
||||
- Fill Down
|
||||
- Blank Down
|
||||
- Transpose Cells in Columns into Rows
|
||||
- Transpose Cells in Rows into Columns (Issue 82)
|
||||
- Move Column to Beginning, Move Column to End, Move Column Left, Move Column Right, Reorder Columns
|
||||
- Add Column by Fetching URLs
|
||||
- Recon commands:
|
||||
- Clear recon data for all matching rows
|
||||
- Clear recon data for one cell
|
||||
- Clear recon data for similar cells
|
||||
- Copy recon judgments across columns
|
||||
- GREL:
|
||||
- JSON support
|
||||
- New functions: smartSplit, escape, parseJson, hasField, uniques
|
||||
- New controls: forEachIndex, forRange, filter
|
||||
- New parameters:
|
||||
- preserveAllTokens on split function
|
||||
- Regexp groups capturing GEL function
|
||||
- Importers
|
||||
- New: RDF exporter (as extension)
|
||||
- New: Json importer
|
||||
- CSV and TSV importers: added support for ignoring quotation marks
|
||||
- Added support for creating a project by pointing to a data file URL.
|
||||
- Text facet's choice count limit is now configurable through preference page
|
||||
- Select All and Unselect All buttons in History Extract dialog
|
||||
- Schema skeleton: support for multiple cells per cell-as nodes, and for conditional links
|
||||
- Optionally convert strings to numbers during split columns operation
|
||||
|
||||
Fixes:
|
||||
- TSV/CSV exporter bug: Gridworks crashed when there were empty cells.
|
||||
- Issue 29: Delivered "Collapse whitespace" transformation does not work
|
||||
- Issue 57: Schema skeleton disappears
|
||||
- Issue 66: Records not excluded with inverted text facet
|
||||
- Issue 69: ControlFunctionRegistry now correctly registers Chomp expression as "chomp" key.
|
||||
- Issue 99: Diff for dates fails with "unknown error" always
|
||||
- Issue 110: Import of single column text file with Postal Codes shows only 1 row with lots of <20> chars (?)
|
||||
- Issue 113: Export filtered rows as tsv or csv fails; html and excel OK
|
||||
- Issue 115: datePart(value,"month") gives zero-based month numbers
|
||||
- Issue 116: CSV/TSV export data includes blank fields for deleted columns
|
||||
- Issue 121: Importing attached file strips backslashes
|
||||
- Issue 122: Exporting to Excel on attached project raises server exception
|
||||
- Issue 125: jsonize not serializing arrays
|
||||
- Issue 126: Large integers formatted in scientific notation in formulas
|
||||
- Issue 127: Add column from Freebase raises exception
|
||||
- Issue 135: Hangs when setting cell value to large JSON string
|
||||
- Issue 138: Numbers should be right-justified
|
||||
- Issue 140: Fix Open Workspace Directory command to work on Windows and Linux
|
||||
- Issue 146: In "Cluster and Edit Column", clicking on entry value to set "Merge?" checkbox does not reflect the final value of operation
|
||||
- Issue 155: Blank browser shown when non-GZIP format is detected during import
|
||||
- Issue 160: Cancel button on Search for Match dialog sometimes not working
|
||||
- Issue 161: Authorize error when trying to Sign In before loading to Freebase
|
||||
- Issue 166: Expression Editor dialog needs UI cleanup on long expressions
|
||||
|
||||
|
||||
1.1 Release (May 27, 2010)
|
||||
|
||||
Features:
|
||||
- Row/record sorting (Issue 32)
|
||||
- CSV exporter (Issue 59)
|
||||
- Mqlwrite exporter
|
||||
- Templating exporter (experimental)
|
||||
|
||||
Fixes:
|
||||
- Issue 34: "Behavior of Text Filter is unpredictable when "regular expression" mode is enabled."
|
||||
Regex was not compiled with case insensitivity flag.
|
||||
- Issue 4: "Match All bug with ZIP code". Numeric values in cells were not stringified first
|
||||
before comparison.
|
||||
- Issue 41: "Envelope quotation marks are removed by CSV importer"
|
||||
- Issue 19: "CSV import is too basic"
|
||||
- Issue 15: "Ability to rename projects"
|
||||
- Issue 16: "Column name collision when adding data from Freebase"
|
||||
- Issue 28: "mql-like preview is not properly unquoting numbers"
|
||||
- Issue 45: "Renaming Cells with Ctrl-Enter produced ERROR"
|
||||
Tentative fix for a concurrent bug.
|
||||
- Issue 46: "Array literals in GEL"
|
||||
- Issue 55: "Use stable sorting for text facets sorted by count"
|
||||
- Issue 53: "Moving the cursor inside the Text Filter box by clicking"
|
||||
- Issue 58: "Meta facet"
|
||||
Supported by the function facetCount()
|
||||
- Issue 14: "Limiting Freebase load to starred records"
|
||||
We load whatever rows that are filtered through, not particularly starred rows.
|
||||
- Issue 49: "Add Edit Cells / Set Null"
|
||||
- Issue 30: "Transform dialog should remember preferred language."
|
||||
- Issue 62: "It'd be nice if URIs were hyperlinked in the data cells"
|
||||
|
||||
Other Changes:
|
||||
- Moved unit tests from JUnit to TestNG
|
||||
|
||||
|
||||
1.0.1 Release (May 12, 2010)
|
||||
|
||||
Fixes:
|
||||
- Issue 2: "Undo History bug" - bulk row starring and flagging operations could not be undone.
|
||||
- Issue 5: "Localized Windows cause save problems for Gridworks" -
|
||||
Windows user IDs that contain unicode characters were not retrieved correctly.
|
||||
- Issue 10: "OAuth fails on sign in" - due to clock offset.
|
||||
- Issue 11: "missing "lang" attribute in MQL generated in schema alignment"
|
||||
- Issue 13: "float rejected from sandbox upload as Json object" - everything was sent as a string.
|
||||
- Issue 17: "Conflated triples - all rows are producing triple with "s" :" $Name_0"" -
|
||||
The Create A New Topic for Each Cell command created shared recon objects.
|
||||
- Issue 18: "Error converting russian characters during edit of single cell"
|
||||
- [partial fix] Issue 19: "CSV import is too basic" - fixed for CSV, not for TSV
|
||||
|
||||
1.0 Release (May 10, 2010)
|
||||
|
||||
First Public Release as Freebase Gridworks
|
||||
|
@ -1,269 +1,390 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<profiles version="11">
|
||||
<profile kind="CodeFormatterProfile" name="OpenRefine" version="11">
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_closing_paren_in_if" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_colon_in_assert" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.brace_position_for_enum_constant" value="end_of_line"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_semicolon" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.align_type_members_on_columns" value="false"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_colon_in_case" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.comment.format_line_comments" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.number_of_empty_lines_to_preserve" value="1"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_between_brackets_in_array_type_reference" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_opening_paren_in_switch" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.blank_lines_between_type_declarations" value="1"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_parenthesized_expression_in_return" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_new_line_in_empty_method_body" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_brace_in_annotation_type_declaration" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.indent_statements_compare_to_body" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_new_line_after_opening_brace_in_array_initializer" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_new_line_after_annotation_on_member" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.format_guardian_clause_on_one_line" value="false"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.comment.insert_new_line_before_root_tags" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_colon_in_for" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.tabulation.size" value="8"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_opening_angle_bracket_in_type_parameters" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.blank_lines_before_imports" value="1"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_colon_in_case" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_comma_in_enum_constant_arguments" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.blank_lines_before_new_chunk" value="1"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.continuation_indentation" value="2"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_binary_operator" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_comma_in_constructor_declaration_parameters" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_opening_paren_in_for" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_comma_in_superinterfaces" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_parameters_in_method_declaration" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_assignment" value="0"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.blank_lines_before_member_type" value="1"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_comma_in_constructor_declaration_throws" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_conditional_expression" value="80"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_paren_in_while" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.comment.indent_parameter_description" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.comment.format_html" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_comma_in_allocation_expression" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_comma_in_method_declaration_throws" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_closing_paren_in_enum_constant" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.comment.format_source_code" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_comma_in_enum_declarations" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_closing_angle_bracket_in_parameterized_type_reference" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_closing_paren_in_annotation" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_between_empty_parens_in_method_declaration" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_colon_in_conditional" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_unary_operator" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_question_in_conditional" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_new_line_in_empty_annotation_declaration" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.indentation.size" value="4"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_comma_in_multiple_local_declarations" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_postfix_operator" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_superinterfaces_in_enum_declaration" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_comma_in_enum_constant_arguments" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_semicolon_in_for" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_closing_paren_in_constructor_declaration" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_at_in_annotation_type_declaration" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_comma_in_explicitconstructorcall_arguments" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.brace_position_for_anonymous_type_declaration" value="end_of_line"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.lineSplit" value="120"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_brace_in_type_declaration" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_brace_in_block" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_new_line_in_empty_type_declaration" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_comma_in_method_invocation_arguments" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_closing_paren_in_while" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_brace_in_enum_constant" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.comment.clear_blank_lines_in_block_comment" value="false"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_at_in_annotation_type_declaration" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_new_line_in_empty_enum_constant" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_opening_angle_bracket_in_type_arguments" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_angle_bracket_in_type_parameters" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_new_line_before_closing_brace_in_array_initializer" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.brace_position_for_array_initializer" value="end_of_line"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_superclass_in_type_declaration" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_opening_paren_in_cast" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_new_line_in_empty_enum_declaration" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_closing_paren_in_synchronized" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.comment.format_header" value="false"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_colon_in_for" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_at_in_annotation" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_new_line_before_else_in_if_statement" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_arguments_in_explicit_constructor_call" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_opening_paren_in_method_declaration" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_comma_in_allocation_expression" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_multiple_fields" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_new_line_at_end_of_file_if_missing" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_comma_in_explicitconstructorcall_arguments" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_new_line_in_empty_block" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.join_wrapped_lines" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_closing_paren_in_cast" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_new_line_before_finally_in_try_statement" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.keep_then_statement_on_same_line" value="false"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_binary_operator" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.indent_body_declarations_compare_to_annotation_declaration_header" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_brace_in_constructor_declaration" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_closing_paren_in_method_declaration" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_expressions_in_array_initializer" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_comma_in_method_declaration_parameters" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.brace_position_for_method_declaration" value="end_of_line"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_opening_paren_in_enum_constant" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_between_empty_parens_in_annotation_type_member_declaration" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_angle_bracket_in_type_arguments" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_opening_angle_bracket_in_parameterized_type_reference" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_paren_in_annotation_type_member_declaration" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.blank_lines_before_field" value="0"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_throws_clause_in_method_declaration" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_paren_in_method_declaration" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_comma_in_constructor_declaration_parameters" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_comma_in_type_parameters" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_paren_in_switch" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.comment.format_javadoc_comments" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_opening_bracket_in_array_allocation_expression" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_paren_in_annotation" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.comment.format_block_comments" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_brace_in_array_initializer" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_new_line_in_empty_anonymous_type_declaration" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_binary_expression" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_between_empty_braces_in_array_initializer" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.wrap_before_binary_operator" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.blank_lines_after_package" value="1"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_paren_in_catch" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_superinterfaces_in_type_declaration" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_colon_in_labeled_statement" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.compiler.codegen.inlineJsrBytecode" value="enabled"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_semicolon_in_for" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_and_in_type_parameter" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_opening_paren_in_catch" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_new_line_before_while_in_do_statement" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.blank_lines_between_import_groups" value="1"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_comma_in_method_declaration_throws" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_prefix_operator" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_ellipsis" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.brace_position_for_constructor_declaration" value="end_of_line"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_question_in_wildcard" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.comment.clear_blank_lines_in_javadoc_comment" value="false"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_arguments_in_allocation_expression" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_comma_in_type_parameters" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.blank_lines_after_imports" value="1"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_colon_in_conditional" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_brace_in_enum_declaration" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_comma_in_parameterized_type_reference" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_new_line_before_catch_in_try_statement" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.compiler.problem.assertIdentifier" value="error"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_arguments_in_enum_constant" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.brace_position_for_block_in_case" value="end_of_line"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.brace_position_for_enum_declaration" value="end_of_line"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_comma_in_for_increments" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_paren_in_for" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.blank_lines_before_first_class_body_declaration" value="1"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.keep_else_statement_on_same_line" value="false"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.indent_empty_lines" value="false"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.comment.insert_new_line_for_parameter" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_parenthesized_expression_in_throw" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_opening_paren_in_while" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_closing_brace_in_block" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.compiler.source" value="1.5"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_comma_in_for_increments" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.indent_body_declarations_compare_to_enum_declaration_header" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_between_empty_parens_in_constructor_declaration" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.comment.line_length" value="80"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_prefix_operator" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.brace_position_for_type_declaration" value="end_of_line"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_assignment_operator" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_new_line_after_annotation_on_parameter" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.compiler.compliance" value="1.5"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_paren_in_method_invocation" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_closing_angle_bracket_in_type_arguments" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.compact_else_if" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_bracket_in_array_reference" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_comma_in_enum_declarations" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_question_in_conditional" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_closing_angle_bracket_in_type_parameters" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_opening_paren_in_method_invocation" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.use_tabs_only_for_leading_indentations" value="false"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_comma_in_type_arguments" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.brace_position_for_switch" value="end_of_line"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_parameters_in_constructor_declaration" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_between_empty_brackets_in_array_allocation_expression" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_closing_paren_in_for" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_paren_in_constructor_declaration" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_paren_in_synchronized" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.number_of_blank_lines_at_beginning_of_method_body" value="0"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_comma_in_annotation" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_angle_bracket_in_parameterized_type_reference" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.indent_switchstatements_compare_to_switch" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_opening_paren_in_constructor_declaration" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.join_lines_in_comments" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_opening_paren_in_annotation" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_opening_paren_in_if" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_colon_in_default" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.compiler.problem.enumIdentifier" value="error"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_comma_in_annotation" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_between_empty_parens_in_enum_constant" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_opening_bracket_in_array_reference" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_new_line_after_annotation_on_local_variable" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_bracket_in_array_type_reference" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_comma_in_array_initializer" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_closing_paren_in_catch" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_opening_paren_in_synchronized" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.keep_empty_array_initializer_on_one_line" value="false"/>
|
||||
<setting id="org.eclipse.jdt.core.compiler.codegen.targetPlatform" value="1.5"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_closing_bracket_in_array_reference" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_closing_paren_in_switch" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_closing_brace_in_array_initializer" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_compact_if" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_question_in_wildcard" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_colon_in_assert" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_brace_in_method_declaration" value="insert"/>
|
||||
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||
<profiles version="21">
|
||||
<profile kind="CodeFormatterProfile" name="OpenRefine" version="21">
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_ellipsis" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_arguments_in_qualified_allocation_expression" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.indent_statements_compare_to_block" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_opening_paren_in_parenthesized_expression" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.indent_body_declarations_compare_to_type_header" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_closing_angle_bracket_in_type_parameters" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_comma_in_type_arguments" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.keep_imple_if_on_one_line" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_between_empty_parens_in_method_invocation" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_comma_in_multiple_local_declarations" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.brace_position_for_annotation_type_declaration" value="end_of_line"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_selector_in_method_invocation" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.indent_body_declarations_compare_to_enum_constant_header" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_brace_in_switch" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_assignment_operator" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.never_indent_line_comments_on_first_column" value="false"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_unary_operator" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_paren_in_if" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_colon_in_labeled_statement" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_bracket_in_array_allocation_expression" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.indent_switchstatements_compare_to_cases" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.continuation_indentation_for_array_initializer" value="2"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_comma_in_enum_declarations" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_comma_in_allocation_expression" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.parentheses_positions_in_for_statment" value="common_lines"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.comment.new_lines_at_block_boundaries" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_comma_in_constructor_declaration_parameters" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.comment.insert_new_line_for_parameter" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_new_line_after_annotation_on_package" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_between_empty_parens_in_enum_constant" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_closing_paren_in_while" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_between_empty_parens_in_annotation_type_member_declaration" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.comment.format_javadoc_comments" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.indentation.size" value="4"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.parentheses_positions_in_enum_constant_declaration" value="common_lines"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_semicolon_in_for" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.align_with_spaces" value="false"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.continuation_indentation" value="2"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.number_of_blank_lines_before_code_block" value="0"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_comma_in_switch_case_expressions" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.blank_lines_after_package" value="1"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_comma_in_multiple_local_declarations" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_arguments_in_enum_constant" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_opening_angle_bracket_in_parameterized_type_reference" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.comment.indent_root_tags" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_enum_constants" value="0"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_comma_in_parameterized_type_reference" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.wrap_before_or_operator_multicatch" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.enabling_tag" value="@formatter:on"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.comment.count_line_length_from_starting_position" value="false"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_record_components" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_throws_clause_in_method_declaration" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_new_line_after_annotation_on_parameter" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.wrap_before_multiplicative_operator" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.keep_then_statement_on_same_line" value="false"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_comma_in_explicitconstructorcall_arguments" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_prefix_operator" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_closing_brace_in_array_initializer" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_opening_angle_bracket_in_type_arguments" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_new_line_after_annotation_on_method" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_parameterized_type_references" value="0"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_logical_operator" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_closing_paren_in_parenthesized_expression" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_comma_in_constructor_declaration_throws" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_throws_clause_in_constructor_declaration" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_arguments_in_method_invocation" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.tabulation.char" value="space"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.blank_lines_before_package" value="1"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_comma_in_method_invocation_arguments" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.indent_breaks_compare_to_cases" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_comma_in_for_inits" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_comma_in_multiple_field_declarations" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_comma_in_superinterfaces" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.put_empty_statement_on_new_line" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_comma_in_method_declaration_parameters" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.blank_lines_before_method" value="1"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_comma_in_multiple_field_declarations" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_comma_in_for_inits" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_brace_in_anonymous_type_declaration" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_closing_paren_in_cast" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_closing_angle_bracket_in_type_arguments" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.never_indent_block_comments_on_first_column" value="false"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_comma_in_array_initializer" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_paren_in_parenthesized_expression" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_paren_in_enum_constant" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.keep_annotation_declaration_on_one_line" value="one_line_never"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_closing_paren_in_record_declaration" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_new_line_after_annotation_on_enum_constant" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_multiplicative_operator" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_and_in_type_parameter" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_between_empty_parens_in_method_invocation" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_assignment_operator" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_brace_in_type_declaration" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_opening_paren_in_for" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.comment.preserve_white_space_between_code_and_line_comments" value="false"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_new_line_after_annotation_on_local_variable" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.blank_lines_before_abstract_method" value="1"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.keep_enum_constant_declaration_on_one_line" value="one_line_never"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.align_variable_declarations_on_columns" value="false"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_closing_paren_in_method_invocation" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_postfix_operator" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_union_type_in_multicatch" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.number_of_blank_lines_at_beginning_of_method_body" value="0"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.keep_else_statement_on_same_line" value="false"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.parentheses_positions_in_catch_clause" value="common_lines"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_comma_in_parameterized_type_reference" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_comma_in_array_initializer" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_comma_in_annotation" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_arguments_in_explicit_constructor_call" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_multiplicative_operator" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.keep_anonymous_type_declaration_on_one_line" value="one_line_never"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_comma_in_switch_case_expressions" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.wrap_before_shift_operator" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.indent_body_declarations_compare_to_annotation_declaration_header" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.brace_position_for_block" value="end_of_line"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_opening_brace_in_array_initializer" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_closing_bracket_in_array_allocation_expression" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.number_of_blank_lines_at_end_of_code_block" value="0"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_bitwise_operator" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.put_empty_statement_on_new_line" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_parameters_in_constructor_declaration" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_type_parameters" value="0"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_compact_loops" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.comment.clear_blank_lines_in_block_comment" value="false"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.keep_simple_for_body_on_same_line" value="false"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_new_line_at_end_of_file_if_missing" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_comma_in_array_initializer" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_unary_operator" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.format_line_comment_starting_on_first_column" value="false"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.parentheses_positions_in_annotation" value="common_lines"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_ellipsis" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_semicolon_in_try_resources" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_colon_in_assert" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_annotations_on_enum_constant" value="0"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_and_in_type_parameter" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_opening_paren_in_parenthesized_expression" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.text_block_indentation" value="0"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.align_type_members_on_columns" value="false"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_assignment" value="0"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_module_statements" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.indent_body_declarations_compare_to_type_header" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_between_empty_parens_in_method_declaration" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.comment.align_tags_names_descriptions" value="false"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_opening_paren_in_enum_constant" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.keep_if_then_body_block_on_one_line" value="one_line_never"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.blank_lines_before_first_class_body_declaration" value="1"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_new_line_before_closing_brace_in_array_initializer" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_comma_in_constructor_declaration_parameters" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.format_guardian_clause_on_one_line" value="false"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_paren_in_if" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.align_assignment_statements_on_columns" value="false"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.brace_position_for_block_in_case" value="end_of_line"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_closing_paren_in_constructor_declaration" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_conditional_expression_chain" value="0"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.comment.format_header" value="false"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_type_annotations" value="0"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_arguments_in_allocation_expression" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.wrap_before_assertion_message_operator" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_closing_paren_in_switch" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_method_declaration" value="0"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.align_fields_grouping_blank_lines" value="2147483647"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.comment.new_lines_at_javadoc_boundaries" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_bitwise_operator" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.brace_position_for_annotation_type_declaration" value="end_of_line"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_colon_in_for" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_resources_in_try" value="80"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_selector_in_method_invocation" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.never_indent_block_comments_on_first_column" value="false"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_opening_paren_in_synchronized" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_comma_in_allocation_expression" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.comment.format_source_code" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_brace_in_array_initializer" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.blank_lines_before_field" value="0"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_at_in_annotation" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.blank_lines_before_method" value="1"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_superclass_in_type_declaration" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_parenthesized_expression_in_throw" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_not_operator" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_new_line_after_type_annotation" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_opening_brace_in_array_initializer" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_paren_in_parenthesized_expression" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.comment.format_html" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_at_in_annotation_type_declaration" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.parentheses_positions_in_method_delcaration" value="common_lines"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_compact_if" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.indent_empty_lines" value="false"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_type_arguments" value="0"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_unary_operator" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_paren_in_enum_constant" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_arguments_in_annotation" value="0"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_comma_in_enum_declarations" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_annotations_on_package" value="49"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.indent_switchstatements_compare_to_switch" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_new_line_before_else_in_if_statement" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_assignment_operator" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_new_line_after_label" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.indent_body_declarations_compare_to_enum_declaration_header" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_colon_in_conditional" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_comma_in_method_declaration_parameters" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_closing_paren_in_cast" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_arrow_in_switch_case" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_new_line_before_while_in_do_statement" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_bracket_in_array_type_reference" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.indent_body_declarations_compare_to_record_header" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_closing_angle_bracket_in_parameterized_type_reference" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_new_line_after_opening_brace_in_array_initializer" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.indent_breaks_compare_to_cases" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_closing_paren_in_method_declaration" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.wrap_before_bitwise_operator" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_opening_paren_in_try" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_lambda_arrow" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_opening_paren_in_method_declaration" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.comment.indent_tag_description" value="false"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.keep_imple_if_on_one_line" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.brace_position_for_record_constructor" value="end_of_line"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_brace_in_enum_declaration" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_between_brackets_in_array_type_reference" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_angle_bracket_in_type_parameters" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_string_concatenation" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_semicolon_in_for" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_bracket_in_array_allocation_expression" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_multiple_fields" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_comma_in_enum_constant_arguments" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_prefix_operator" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.brace_position_for_array_initializer" value="end_of_line"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_shift_operator" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_brace_in_method_declaration" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_comma_in_type_parameters" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_closing_paren_in_catch" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_shift_operator" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_between_empty_braces_in_array_initializer" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_comma_in_multiple_local_declarations" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.keep_simple_do_while_body_on_same_line" value="false"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_brace_in_annotation_type_declaration" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_comma_in_record_components" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.wrap_outer_expressions_when_nested" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_closing_paren_in_cast" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_paren_in_synchronized" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_paren_in_annotation_type_member_declaration" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_expressions_in_for_loop_header" value="0"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.wrap_before_additive_operator" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.keep_simple_getter_setter_on_one_line" value="false"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_opening_paren_in_while" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_opening_angle_bracket_in_type_parameters" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_string_concatenation" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_lambda_arrow" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.join_lines_in_comments" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_paren_in_record_declaration" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_relational_operator" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_comma_in_multiple_field_declarations" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.blank_lines_between_import_groups" value="1"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_at_in_annotation_type_declaration" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_logical_operator" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.parentheses_positions_in_method_invocation" value="common_lines"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.blank_lines_after_imports" value="1"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.comment.insert_new_line_before_root_tags" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.parentheses_positions_in_record_declaration" value="common_lines"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_comma_in_method_declaration_throws" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.parentheses_positions_in_switch_statement" value="common_lines"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_postfix_operator" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_comma_in_for_increments" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_comma_in_type_arguments" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_arrow_in_switch_default" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_comma_in_for_inits" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.disabling_tag" value="@formatter:off"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_enum_constants" value="0"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.blank_lines_before_imports" value="1"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.number_of_blank_lines_at_end_of_method_body" value="0"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.parentheses_positions_in_if_while_statement" value="common_lines"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_closing_brace_in_block" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_parenthesized_expression_in_return" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_arrow_in_switch_case" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_new_line_after_annotation_on_field" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.blank_lines_between_type_declarations" value="1"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_closing_paren_in_for" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_opening_paren_in_catch" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_opening_paren_in_switch" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_brace_in_anonymous_type_declaration" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.never_indent_line_comments_on_first_column" value="false"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_comma_in_for_inits" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.indent_statements_compare_to_block" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.brace_position_for_anonymous_type_declaration" value="end_of_line"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_question_in_wildcard" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_paren_in_annotation" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_comma_in_method_invocation_arguments" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_brace_in_switch" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.comment.align_tags_descriptions_grouped" value="false"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.comment.line_length" value="120"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.use_on_off_tags" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.keep_method_body_on_one_line" value="one_line_never"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_between_empty_brackets_in_array_allocation_expression" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.keep_loop_body_block_on_one_line" value="one_line_never"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_brace_in_enum_constant" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.brace_position_for_method_declaration" value="end_of_line"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_colon_in_for" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.keep_type_declaration_on_one_line" value="one_line_never"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_closing_angle_bracket_in_type_arguments" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_additive_operator" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_comma_in_multiple_field_declarations" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_brace_in_record_constructor" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_relational_operator" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_comma_in_superinterfaces" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.keep_record_declaration_on_one_line" value="one_line_never"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_colon_in_default" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_question_in_conditional" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.brace_position_for_constructor_declaration" value="end_of_line"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.brace_position_for_lambda_body" value="end_of_line"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.compact_else_if" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_comma_in_type_parameters" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_paren_in_catch" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_paren_in_method_invocation" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_comma_in_method_invocation_arguments" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_arguments_in_method_invocation" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_throws_clause_in_constructor_declaration" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_new_line_before_catch_in_try_statement" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_paren_in_try" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_annotations_on_parameter" value="0"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.comment.clear_blank_lines_in_javadoc_comment" value="false"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_relational_operator" value="0"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_expressions_in_array_initializer" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.number_of_empty_lines_to_preserve" value="1"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_colon_in_case" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_additive_operator" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_closing_paren_in_if" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_comma_in_type_arguments" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_string_concatenation" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.comment.format_line_comments" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.brace_position_for_record_declaration" value="end_of_line"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_colon_in_labeled_statement" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.number_of_blank_lines_after_code_block" value="0"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_superinterfaces_in_type_declaration" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_conditional_expression" value="80"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_new_line_after_annotation_on_type" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_annotations_on_type" value="49"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_brace_in_block" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_annotations_on_local_variable" value="49"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.brace_position_for_enum_declaration" value="end_of_line"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_arrow_in_switch_default" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.comment.insert_new_line_between_different_tags" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_additive_operator" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_opening_paren_in_method_invocation" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_paren_in_while" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.join_wrapped_lines" value="false"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_between_empty_parens_in_constructor_declaration" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_annotations_on_field" value="49"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.wrap_before_conditional_operator" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.indent_switchstatements_compare_to_cases" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_closing_bracket_in_array_allocation_expression" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_closing_paren_in_synchronized" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_shift_operator" value="0"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.use_tabs_only_for_leading_indentations" value="false"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.parentheses_positions_in_try_clause" value="common_lines"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.keep_code_block_on_one_line" value="one_line_never"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_comma_in_constructor_declaration_throws" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_comma_in_record_components" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.tabulation.size" value="4"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_bitwise_operator" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_opening_bracket_in_array_reference" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_colon_in_conditional" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_closing_paren_in_try" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_semicolon_in_try_resources" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.continuation_indentation_for_array_initializer" value="2"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_question_in_wildcard" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_opening_paren_in_record_declaration" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_superinterfaces_in_enum_declaration" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.wrap_before_assignment_operator" value="false"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_colon_in_labeled_statement" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.brace_position_for_switch" value="end_of_line"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_comma_in_superinterfaces" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_comma_in_method_declaration_parameters" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_closing_angle_bracket_in_type_parameters" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.keep_lambda_body_block_on_one_line" value="one_line_never"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_annotations_on_method" value="49"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_comma_in_parameterized_type_reference" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.keep_record_constructor_on_one_line" value="one_line_never"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_brace_in_record_declaration" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.keep_empty_array_initializer_on_one_line" value="false"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_assertion_message" value="0"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_paren_in_constructor_declaration" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.blank_lines_before_new_chunk" value="1"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_opening_bracket_in_array_allocation_expression" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_opening_paren_in_constructor_declaration" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_angle_bracket_in_parameterized_type_reference" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_closing_angle_bracket_in_type_arguments" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_colon_in_assert" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.blank_lines_before_member_type" value="1"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_logical_operator" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_arguments_in_qualified_allocation_expression" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_superinterfaces_in_record_declaration" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_opening_paren_in_if" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_semicolon" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.wrap_before_relational_operator" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_postfix_operator" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_angle_bracket_in_type_arguments" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_opening_paren_in_cast" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.comment.format_block_comments" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.alignment_for_parameters_in_method_declaration" value="16"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_comma_in_method_declaration_throws" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.blank_lines_after_last_class_body_declaration" value="0"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.indent_statements_compare_to_body" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.keep_simple_while_body_on_same_line" value="false"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.wrap_before_logical_operator" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.blank_lines_between_statement_group_in_switch" value="0"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_closing_bracket_in_array_reference" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_comma_in_annotation" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_comma_in_enum_constant_arguments" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.parentheses_positions_in_lambda_declaration" value="common_lines"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_colon_in_case" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_bracket_in_array_reference" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.keep_enum_declaration_on_one_line" value="one_line_never"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_paren_in_method_declaration" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.brace_position_for_enum_constant" value="end_of_line"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.brace_position_for_type_declaration" value="end_of_line"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_multiplicative_operator" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.blank_lines_before_package" value="1"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_paren_in_for" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_comma_in_for_increments" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_closing_paren_in_enum_constant" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_comma_in_explicitconstructorcall_arguments" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_closing_paren_in_annotation" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.indent_body_declarations_compare_to_enum_constant_header" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_brace_in_constructor_declaration" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_comma_in_constructor_declaration_throws" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_closing_angle_bracket_in_type_parameters" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_question_in_conditional" value="insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.comment.indent_parameter_description" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.number_of_blank_lines_at_beginning_of_code_block" value="0"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_new_line_before_finally_in_try_statement" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.tabulation.char" value="space"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.wrap_before_string_concatenation" value="true"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.lineSplit" value="140"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_after_opening_paren_in_annotation" value="do not insert"/>
|
||||
<setting id="org.eclipse.jdt.core.formatter.insert_space_before_opening_paren_in_switch" value="insert"/>
|
||||
</profile>
|
||||
</profiles>
|
||||
|
@ -1,13 +1,3 @@
|
||||
# MultiUserOpenRefine
|
||||
![MultiUserOpenRefine](logo.svg)
|
||||
|
||||
MultiUserOpenRefine is an extension to open-source tool that, in addition to
|
||||
all the features described below, allows creating user accounts, each providing
|
||||
private workspace and leaving the convenience of running the basic OpenRefine
|
||||
tool on a remote server.
|
||||
|
||||
Project is being developed at Adam Mickiewicz University in Poznań by students.
|
||||
|
||||
# OpenRefine
|
||||
|
||||
[![DOI](https://zenodo.org/badge/6220644.svg)](https://zenodo.org/badge/latestdoi/6220644)
|
||||
@ -27,8 +17,8 @@ the web. All from a web browser and the comfort and privacy of your own computer
|
||||
|
||||
Latest development version, packaged for:
|
||||
* [Linux](https://oss.sonatype.org/service/local/artifact/maven/content?r=snapshots&g=org.openrefine&a=openrefine&v=3.6-SNAPSHOT&c=linux&p=tar.gz)
|
||||
* [Windows](https://oss.sonatype.org/service/local/artifact/maven/content?r=snapshots&g=org.openrefine&a=openrefine&v=3.6-SNAPSHOT&c=mac&p=dmg)
|
||||
* [MacOS](https://oss.sonatype.org/service/local/artifact/maven/content?r=snapshots&g=org.openrefine&a=openrefine&v=3.6-SNAPSHOT&c=win&p=zip)
|
||||
* [MacOS](https://oss.sonatype.org/service/local/artifact/maven/content?r=snapshots&g=org.openrefine&a=openrefine&v=3.6-SNAPSHOT&c=mac&p=dmg)
|
||||
* [Windows](https://oss.sonatype.org/service/local/artifact/maven/content?r=snapshots&g=org.openrefine&a=openrefine&v=3.6-SNAPSHOT&c=win&p=zip)
|
||||
|
||||
## Run from source
|
||||
|
||||
@ -72,4 +62,4 @@ was acquired by Google, Inc. in July 2010 and the product was renamed Google Ref
|
||||
In October 2012, it was renamed OpenRefine as it transitioned to a
|
||||
community-supported product.
|
||||
|
||||
See [AUTHORS.md](./AUTHORS.md) for the list of OpenRefine contributors and [CONTRIBUTING.md](./CONTRIBUTING.md) for instructions on how to contribute yourself.
|
||||
See [CONTRIBUTING.md](./CONTRIBUTING.md) for instructions on how to contribute yourself.
|
||||
|
@ -4,8 +4,8 @@
|
||||
|
||||
| Version | Supported |
|
||||
| ------- | ------------------ |
|
||||
| 3.4.x | :white_check_mark: |
|
||||
| <= 3.3 | :x: |
|
||||
| 3.5.x | :white_check_mark: |
|
||||
| <= 3.4 | :x: |
|
||||
|
||||
## Reporting a Vulnerability
|
||||
|
||||
|
@ -1,8 +0,0 @@
|
||||
An evergrowing list of our forever immortalized OpenRefine Backers that we LOVE because they help support further development !
|
||||
|
||||
1. Owen Stephens - Wiki contributor, extension author, and supporting you in our mailing list.
|
||||
2. PaulZH -
|
||||
3. Jens Willmer -
|
||||
4. mroswell -
|
||||
5. Google News Initiative - https://newsinitiative.withgoogle.com/
|
||||
6. Chan Zuckerberg Initiative - https://chanzuckerberg.com/
|
@ -48,7 +48,7 @@
|
||||
|
||||
<properties>
|
||||
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
|
||||
<jmh.version>1.33</jmh.version>
|
||||
<jmh.version>1.34</jmh.version>
|
||||
<javac.target>${java.minversion}</javac.target>
|
||||
<uberjar.name>openrefine-benchmarks</uberjar.name>
|
||||
</properties>
|
||||
@ -58,7 +58,7 @@
|
||||
<plugin>
|
||||
<groupId>org.apache.maven.plugins</groupId>
|
||||
<artifactId>maven-compiler-plugin</artifactId>
|
||||
<version>3.8.0</version>
|
||||
<version>3.9.0</version>
|
||||
<configuration>
|
||||
<compilerVersion>${javac.target}</compilerVersion>
|
||||
<source>${javac.target}</source>
|
||||
@ -119,7 +119,7 @@
|
||||
</plugin>
|
||||
<plugin>
|
||||
<artifactId>maven-jar-plugin</artifactId>
|
||||
<version>2.4</version>
|
||||
<version>${maven-jar-plugin.version}</version>
|
||||
</plugin>
|
||||
<plugin>
|
||||
<artifactId>maven-javadoc-plugin</artifactId>
|
||||
@ -131,7 +131,7 @@
|
||||
</plugin>
|
||||
<plugin>
|
||||
<artifactId>maven-site-plugin</artifactId>
|
||||
<version>3.9.1</version>
|
||||
<version>3.10.0</version>
|
||||
</plugin>
|
||||
<plugin>
|
||||
<artifactId>maven-source-plugin</artifactId>
|
||||
|
@ -24,6 +24,7 @@
|
||||
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||
* POSSIBILITY OF SUCH DAMAGE.
|
||||
******************************************************************************/
|
||||
|
||||
package org.openrefine.benchmark;
|
||||
|
||||
import java.util.Properties;
|
||||
@ -91,4 +92,3 @@ public class ToNumberBenchmark {
|
||||
blackhole.consume(plan.f.call(bindings, plan.args));
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -5,7 +5,7 @@ We use [Docusaurus 2](https://v2.docusaurus.io/) for our docs, a modern static w
|
||||
|
||||
### Requirements
|
||||
|
||||
Assuming you have [Node.js](https://nodejs.org/en/download/) installed (which includes npm), you can install Docusaurus with:
|
||||
Assuming you have [Node.js (LTS recommended)](https://nodejs.org/en/download/) installed (which includes npm), you can install Docusaurus with:
|
||||
|
||||
You will need to install [Yarn](https://yarnpkg.com/getting-started/install) before you can build the site.
|
||||
|
||||
@ -66,6 +66,18 @@ yarn build
|
||||
```
|
||||
|
||||
This command generates static content into the `build` directory and can be served using any static contents hosting service.
|
||||
### (Optional) Test Build Locally
|
||||
You can locally test ([with parameters](https://docusaurus.io/docs/cli#docusaurus-serve-sitedir)) the static content in the `build` directory (in case you don't have access to a hosting service) by using:
|
||||
|
||||
```sh
|
||||
yarn serve
|
||||
```
|
||||
|
||||
or to build and then serve locally with one command:
|
||||
|
||||
```sh
|
||||
yarn serve --build
|
||||
```
|
||||
|
||||
### Deployment
|
||||
|
||||
|
@ -20,7 +20,7 @@ OpenRefine is designed to work with **Windows**, **Mac**, and **Linux** operatin
|
||||
|
||||
If you install and start OpenRefine on a Windows computer without Java, it will automatically open up a browser window to the [Java downloads page](https://java.com/en/download/), and you can simply follow the instructions there.
|
||||
|
||||
We recommend you [download](https://java.com/en/download/) and install Java before proceeding with the OpenRefine installation. Please note that OpenRefine works with Java 8 to Java 15 but not Java 16 or later versions.
|
||||
We recommend you [download](https://java.com/en/download/) and install Java before proceeding with the OpenRefine installation. Please note that OpenRefine 3.5 works with Java 8 to Java 17.
|
||||
|
||||
#### Compatible browser {#compatible-browser}
|
||||
|
||||
|
@ -321,7 +321,7 @@ From the home screen, look in the options to the left for <span class="menuItems
|
||||
To leave the Language Settings screen, click on the diamond “OpenRefine” logo.
|
||||
|
||||
:::info Help us Translate OpenRefine
|
||||
We use Weblate to provide translations for the interface. You can check [our profile on Weblate](https://hosted.weblate.org/projects/openrefine/translations/) to see which languages are in the process of being supported. See [our technical reference if you are interested in contributing translation work](https://docs.openrefine.org/technical-reference/translating) to make OpenRefine accessible to people in other languages.
|
||||
We use Weblate to provide translations for the interface. You can check [our profile on Weblate](https://hosted.weblate.org/projects/openrefine/translations/) to see which languages are in the process of being supported. See [our technical reference if you are interested in contributing translation work](../technical-reference/translating-ui) to make OpenRefine accessible to people in other languages.
|
||||
:::
|
||||
|
||||
### Preferences {#preferences}
|
||||
|
@ -33,3 +33,9 @@ You can control what data you view in the grid. On each column, you will see a <
|
||||
You can find, under <span class="menuItems">All</span> → <span class="menuItems">View</span>, the option to show and hide [“null” values](exploring#data-types). A small grey “null” will appear in each applicable cell. Remember that a null cell is not the same thing as an empty cell.
|
||||
|
||||
![A screenshot of what a null value looks like.](/img/null.png)
|
||||
|
||||
## Page navigation {#page-navigation}
|
||||
|
||||
You can go directly to any page by changing the page number on the right-hand side. Using the up and down arrow keys in this input lets you go to the next and previous pages. You can also change the number of rows or records per page on the left-hand side of this view header bar.
|
||||
|
||||
![A screenshot of the Page Navigation Feature.](/img/goto.png)
|
||||
|
@ -22,8 +22,8 @@ If you don’t find your problem and solution there, continue on to the resource
|
||||
* Then, if you wish, you can create a Github issue.
|
||||
|
||||
### If you want to contribute: {#if-you-want-to-contribute}
|
||||
* [Help us translate the tool into more languages](https://docs.openrefine.org/technical-reference/translating), using Weblate
|
||||
* [We have a guide to contributing](technical-reference/contributing) in the [Technical Reference](technical-reference/technical-reference-index) section
|
||||
* [Help us translate the tool into more languages](../technical-reference/translating-ui), using Weblate
|
||||
* [We have a guide to contributing](../technical-reference/contributing) in the [Technical Reference](../technical-reference/technical-reference-index) section
|
||||
* Contribute your feature requests in the [User forum](https://groups.google.com/g/openrefine) or as [Github issues](https://github.com/OpenRefine/OpenRefine/issues/new/choose)
|
||||
* Join the User Forum and/or the [Developer Forum](https://groups.google.com/g/openrefine-dev)
|
||||
* Share your successes and use cases with us, in the User forum
|
||||
|
@ -230,6 +230,13 @@ Right click on the `server` subproject, click `Run as...` and `Run configuration
|
||||
|
||||
This will add a run configuration that you can then use to run OpenRefine from Eclipse.
|
||||
|
||||
## Code style in Eclipse
|
||||
|
||||
You can apply the supplied Eclipse code style (in `IDEs/eclipse/Refine.style.xml`) to make sure Eclipse lints your files according to the existing style.
|
||||
Pull requests deviating from this style will fail in the CI.
|
||||
|
||||
You can manually apply the code style (regardless of your IDE) with the `mvn formatter:format` command.
|
||||
|
||||
## Testing in Eclipse {#testing-in-eclipse}
|
||||
|
||||
You can run the server tests directly from Eclipse. To do that you need to have the TestNG launcher plugin installed, as well as the TestNG M2E plugin (for integration with Maven). If you don't have it, you can get it by [installing new software](https://help.eclipse.org/2020-03/index.jsp?topic=/org.eclipse.platform.doc.user/tasks/tasks-129.htm) from this update URL http://dl.bintray.com/testng-team/testng-eclipse-release/
|
||||
|
@ -61,6 +61,8 @@ This describes the overall steps to your first code contribution in OpenRefine.
|
||||
|
||||
- Make changes to the code to fix the issue. If you are changing backend code, it would be great if you could also write a test in Java to demonstrate the fix. You can imitate existing tests for that. We currently do not have frontend tests.
|
||||
|
||||
- If you made Java changes, run linting to make sure they conform to our code style, with `mvn formatter:format`.
|
||||
|
||||
- commit your changes, using a message that contains one of the special words "closes" and "fixes" which are detected by Github, followed by the issue number, e.g. "closes #1234" or "fixes #1234", this will link the commit to the issue you are working on.
|
||||
|
||||
- push your branch to your fork and create a pull request for it, explaining the approach you have used, any design decisions you have made.
|
||||
|
@ -10,7 +10,7 @@ When releasing a new version of Refine, the following steps should be followed:
|
||||
2. Change the version number in [RefineServlet.java](http://github.com/OpenRefine/OpenRefine/blob/master/main/src/com/google/refine/RefineServlet.java#L62) and in the POM files using `mvn versions:set -DnewVersion=2.6-beta -DgenerateBackupPoms=false`. Commit the changes.
|
||||
3. Compose the list of changes in the code and on the wiki. If the issues have been updated with the appropriate milestone, the Github issue tracker should be able to provide a good starting point for this.
|
||||
4. Set up build machine. This needs to be Mac OS X or Linux.
|
||||
5. Download Windows and Mac JREs to bundle them in the Windows and Mac packages from [AdoptOpenJDK](https://adoptopenjdk.net/). You only need the JREs, not the JDKs. Use the lowest version of Java supported (Java 8 currently). Configure the location of these JREs in the `settings.xml` file at the root of the repository. It is important to download recent versions of the JREs as this impacts which HTTPS certificates are accepted by the tool.
|
||||
5. Download Windows and Mac JREs to bundle them in the Windows and Mac packages from [AdoptOpenJDK](https://adoptopenjdk.net/). You only need the JREs, not the JDKs. Use the lowest version of Java supported (Java 11 currently). Configure the location of these JREs in the `settings.xml` file at the root of the repository. It is important to download recent versions of the JREs as this impacts which HTTPS certificates are accepted by the tool.
|
||||
6. Insert the production Google credentials in https://github.com/OpenRefine/OpenRefine/blob/bc540a880eceb88e54f85ca43eb54769de3bfa4f/extensions/gdata/src/com/google/refine/extension/gdata/GoogleAPIExtension.java#L36-L39 without committing the changes.
|
||||
7. [Build the release candidate kits using the shell script (not just Maven)](https://github.com/OpenRefine/OpenRefine/wiki/Building-OpenRefine-From-Source). This must be done on Mac OS X or Linux to be able to build all 3 kits. On Linux you will need to install the `genisoimage` program first.
|
||||
```shell
|
||||
|
BIN
OpenRefine/docs/static/img/goto.png
vendored
Normal file
BIN
OpenRefine/docs/static/img/goto.png
vendored
Normal file
Binary file not shown.
After Width: | Height: | Size: 18 KiB |
@ -319,7 +319,7 @@ From the home screen, look in the options to the left for <span class="menuItems
|
||||
To leave the Language Settings screen, click on the diamond “OpenRefine” logo.
|
||||
|
||||
:::info Help us Translate OpenRefine
|
||||
We use Weblate to provide translations for the interface. You can check [our profile on Weblate](https://hosted.weblate.org/projects/openrefine/translations/) to see which languages are in the process of being supported. See [our technical reference if you are interested in contributing translation work](https://docs.openrefine.org/technical-reference/translating) to make OpenRefine accessible to people in other languages.
|
||||
We use Weblate to provide translations for the interface. You can check [our profile on Weblate](https://hosted.weblate.org/projects/openrefine/translations/) to see which languages are in the process of being supported. See [our technical reference if you are interested in contributing translation work](../technical-reference/translating) to make OpenRefine accessible to people in other languages.
|
||||
:::
|
||||
|
||||
### Preferences {#preferences}
|
||||
|
@ -22,8 +22,8 @@ If you don’t find your problem and solution there, continue on to the resource
|
||||
* Then, if you wish, you can create a Github issue.
|
||||
|
||||
### If you want to contribute: {#if-you-want-to-contribute}
|
||||
* [Help us translate the tool into more languages](https://docs.openrefine.org/technical-reference/translating), using Weblate
|
||||
* [We have a guide to contributing](technical-reference/contributing) in the [Technical Reference](technical-reference/technical-reference-index) section
|
||||
* [Help us translate the tool into more languages](../technical-reference/translating), using Weblate
|
||||
* [We have a guide to contributing](../technical-reference/contributing) in the [Technical Reference](../technical-reference/technical-reference-index) section
|
||||
* Contribute your feature requests in the [User forum](https://groups.google.com/g/openrefine) or as [Github issues](https://github.com/OpenRefine/OpenRefine/issues/new/choose)
|
||||
* Join the User Forum and/or the [Developer Forum](https://groups.google.com/g/openrefine-dev)
|
||||
* Share your successes and use cases with us, in the User forum
|
||||
|
@ -20,7 +20,7 @@ OpenRefine is designed to work with **Windows**, **Mac**, and **Linux** operatin
|
||||
|
||||
If you install and start OpenRefine on a Windows computer without Java, it will automatically open up a browser window to the [Java downloads page](https://java.com/en/download/), and you can simply follow the instructions there.
|
||||
|
||||
We recommend you [download](https://java.com/en/download/) and install Java before proceeding with the OpenRefine installation. Please note that OpenRefine works with Java 8 to Java 15 but not Java 16 or later versions.
|
||||
We recommend you [download](https://java.com/en/download/) and install Java before proceeding with the OpenRefine installation. Please note that OpenRefine works with Java 8 to Java 17 for OpenRefine 3.5.
|
||||
|
||||
#### Compatible browser {#compatible-browser}
|
||||
|
||||
|
@ -321,7 +321,7 @@ From the home screen, look in the options to the left for <span class="menuItems
|
||||
To leave the Language Settings screen, click on the diamond “OpenRefine” logo.
|
||||
|
||||
:::info Help us Translate OpenRefine
|
||||
We use Weblate to provide translations for the interface. You can check [our profile on Weblate](https://hosted.weblate.org/projects/openrefine/translations/) to see which languages are in the process of being supported. See [our technical reference if you are interested in contributing translation work](https://docs.openrefine.org/technical-reference/translating) to make OpenRefine accessible to people in other languages.
|
||||
We use Weblate to provide translations for the interface. You can check [our profile on Weblate](https://hosted.weblate.org/projects/openrefine/translations/) to see which languages are in the process of being supported. See [our technical reference if you are interested in contributing translation work](../technical-reference/translating-ui) to make OpenRefine accessible to people in other languages.
|
||||
:::
|
||||
|
||||
### Preferences {#preferences}
|
||||
|
@ -33,3 +33,9 @@ You can control what data you view in the grid. On each column, you will see a <
|
||||
You can find, under <span class="menuItems">All</span> → <span class="menuItems">View</span>, the option to show and hide [“null” values](exploring#data-types). A small grey “null” will appear in each applicable cell. Remember that a null cell is not the same thing as an empty cell.
|
||||
|
||||
![A screenshot of what a null value looks like.](/img/null.png)
|
||||
|
||||
## Page navigation {#page-navigation}
|
||||
|
||||
You can go directly to any page by changing the page number on the right-hand side. Using the up and down arrow keys in this input lets you go to the next and previous pages. You can also change the number of rows or records per page on the left-hand side of this view header bar.
|
||||
|
||||
![A screenshot of the Page Navigation Feature.](/img/goto.png)
|
||||
|
@ -22,8 +22,8 @@ If you don’t find your problem and solution there, continue on to the resource
|
||||
* Then, if you wish, you can create a Github issue.
|
||||
|
||||
### If you want to contribute: {#if-you-want-to-contribute}
|
||||
* [Help us translate the tool into more languages](https://docs.openrefine.org/technical-reference/translating), using Weblate
|
||||
* [We have a guide to contributing](technical-reference/contributing) in the [Technical Reference](technical-reference/technical-reference-index) section
|
||||
* [Help us translate the tool into more languages](../technical-reference/translating-ui), using Weblate
|
||||
* [We have a guide to contributing](../technical-reference/contributing) in the [Technical Reference](../technical-reference/technical-reference-index) section
|
||||
* Contribute your feature requests in the [User forum](https://groups.google.com/g/openrefine) or as [Github issues](https://github.com/OpenRefine/OpenRefine/issues/new/choose)
|
||||
* Join the User Forum and/or the [Developer Forum](https://groups.google.com/g/openrefine-dev)
|
||||
* Share your successes and use cases with us, in the User forum
|
||||
|
@ -230,6 +230,13 @@ Right click on the `server` subproject, click `Run as...` and `Run configuration
|
||||
|
||||
This will add a run configuration that you can then use to run OpenRefine from Eclipse.
|
||||
|
||||
## Code style in Eclipse
|
||||
|
||||
You can apply the supplied Eclipse code style (in `IDEs/eclipse/Refine.style.xml`) to make sure Eclipse lints your files according to the existing style.
|
||||
Pull requests deviating from this style will fail in the CI.
|
||||
|
||||
You can manually apply the code style (regardless of your IDE) with the `mvn formatter:format` command.
|
||||
|
||||
## Testing in Eclipse {#testing-in-eclipse}
|
||||
|
||||
You can run the server tests directly from Eclipse. To do that you need to have the TestNG launcher plugin installed, as well as the TestNG M2E plugin (for integration with Maven). If you don't have it, you can get it by [installing new software](https://help.eclipse.org/2020-03/index.jsp?topic=/org.eclipse.platform.doc.user/tasks/tasks-129.htm) from this update URL http://dl.bintray.com/testng-team/testng-eclipse-release/
|
||||
|
@ -61,6 +61,8 @@ This describes the overall steps to your first code contribution in OpenRefine.
|
||||
|
||||
- Make changes to the code to fix the issue. If you are changing backend code, it would be great if you could also write a test in Java to demonstrate the fix. You can imitate existing tests for that. We currently do not have frontend tests.
|
||||
|
||||
- If you made Java changes, run linting to make sure they conform to our code style, with `mvn formatter:format`.
|
||||
|
||||
- commit your changes, using a message that contains one of the special words "closes" and "fixes" which are detected by Github, followed by the issue number, e.g. "closes #1234" or "fixes #1234", this will link the commit to the issue you are working on.
|
||||
|
||||
- push your branch to your fork and create a pull request for it, explaining the approach you have used, any design decisions you have made.
|
||||
|
@ -1432,9 +1432,9 @@
|
||||
to-fast-properties "^2.0.0"
|
||||
|
||||
"@crowdin/cli@3":
|
||||
version "3.7.2"
|
||||
resolved "https://registry.yarnpkg.com/@crowdin/cli/-/cli-3.7.2.tgz#709597ead041359b213e0804d4c8b9f8f8a14dcd"
|
||||
integrity sha512-dM7pQLHo10XnHvi0RAkOFAwqn/LB4NE42njn4dHSu8O30zLgsVbCEq4KvUajE2aFz0mDeAzMgxjEDJSssFUf2Q==
|
||||
version "3.7.7"
|
||||
resolved "https://registry.yarnpkg.com/@crowdin/cli/-/cli-3.7.7.tgz#0d2baf888b37aac1cd8d8cb484b0826fa7b82a26"
|
||||
integrity sha512-wN0NXLDymC9PgT3I6jMx/YLjcEtegAnFg7VaavzLfc1vFegD4lKlrvRmc0qV2IIiRMZLShEsS0QtYtAyhi/qew==
|
||||
dependencies:
|
||||
shelljs "^0.8.4"
|
||||
|
||||
@ -2945,20 +2945,10 @@ caniuse-api@^3.0.0:
|
||||
lodash.memoize "^4.1.2"
|
||||
lodash.uniq "^4.5.0"
|
||||
|
||||
caniuse-lite@^1.0.0, caniuse-lite@^1.0.30001214:
|
||||
version "1.0.30001219"
|
||||
resolved "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30001219.tgz#5bfa5d0519f41f993618bd318f606a4c4c16156b"
|
||||
integrity sha512-c0yixVG4v9KBc/tQ2rlbB3A/bgBFRvl8h8M4IeUbqCca4gsiCfvtaheUssbnux/Mb66Vjz7x8yYjDgYcNQOhyQ==
|
||||
|
||||
caniuse-lite@^1.0.30001125, caniuse-lite@^1.0.30001272, caniuse-lite@^1.0.30001280:
|
||||
version "1.0.30001286"
|
||||
resolved "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30001286.tgz#3e9debad420419618cfdf52dc9b6572b28a8fff6"
|
||||
integrity sha512-zaEMRH6xg8ESMi2eQ3R4eZ5qw/hJiVsO/HlLwniIwErij0JDr9P+8V4dtx1l+kLq6j3yy8l8W4fst1lBnat5wQ==
|
||||
|
||||
caniuse-lite@^1.0.30001219:
|
||||
version "1.0.30001220"
|
||||
resolved "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30001220.tgz#c080e1c8eefb99f6cc9685da6313840bdbaf4c36"
|
||||
integrity sha512-pjC2T4DIDyGAKTL4dMvGUQaMUHRmhvPpAgNNTa14jaBWHu+bLQgvpFqElxh9L4829Fdx0PlKiMp3wnYldRtECA==
|
||||
caniuse-lite@^1.0.0, caniuse-lite@^1.0.30001125, caniuse-lite@^1.0.30001214, caniuse-lite@^1.0.30001219, caniuse-lite@^1.0.30001272, caniuse-lite@^1.0.30001280:
|
||||
version "1.0.30001303"
|
||||
resolved "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001303.tgz"
|
||||
integrity sha512-/Mqc1oESndUNszJP0kx0UaQU9kEv9nNtJ7Kn8AdA0mNnH8eR1cj0kG+NbNuC1Wq/b21eA8prhKRA3bbkjONegQ==
|
||||
|
||||
ccount@^1.0.0, ccount@^1.0.3:
|
||||
version "1.1.0"
|
||||
@ -4499,9 +4489,9 @@ flux@^4.0.1:
|
||||
fbjs "^3.0.0"
|
||||
|
||||
follow-redirects@^1.0.0, follow-redirects@^1.14.0:
|
||||
version "1.14.3"
|
||||
resolved "https://registry.yarnpkg.com/follow-redirects/-/follow-redirects-1.14.3.tgz#6ada78118d8d24caee595595accdc0ac6abd022e"
|
||||
integrity sha512-3MkHxknWMUtb23apkgz/83fDoe+y+qr0TdgacGIA7bew+QLBo3vdgEN2xEsuXNivpFy4CyDhBBZnNZOtalmenw==
|
||||
version "1.14.7"
|
||||
resolved "https://registry.yarnpkg.com/follow-redirects/-/follow-redirects-1.14.7.tgz#2004c02eb9436eee9a21446a6477debf17e81685"
|
||||
integrity sha512-+hbxoLbFMbRKDwohX8GkTataGqO6Jb7jGwpAlwgy2bIz25XtRm7KEzJM76R1WiNT5SwZkX4Y75SwBolkpmE7iQ==
|
||||
|
||||
for-in@^1.0.2:
|
||||
version "1.0.2"
|
||||
@ -4655,19 +4645,7 @@ glob-to-regexp@^0.4.1:
|
||||
resolved "https://registry.yarnpkg.com/glob-to-regexp/-/glob-to-regexp-0.4.1.tgz#c75297087c851b9a578bd217dd59a92f59fe546e"
|
||||
integrity sha512-lkX1HJXwyMcprw/5YUZc2s7DrpAiHB21/V+E1rHUrVNokkvB6bqMzT0VfV6/86ZNabt1k14YOIaT7nDvOX3Iiw==
|
||||
|
||||
glob@^7.0.0, glob@^7.1.3:
|
||||
version "7.1.6"
|
||||
resolved "https://registry.yarnpkg.com/glob/-/glob-7.1.6.tgz#141f33b81a7c2492e125594307480c46679278a6"
|
||||
integrity sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==
|
||||
dependencies:
|
||||
fs.realpath "^1.0.0"
|
||||
inflight "^1.0.4"
|
||||
inherits "2"
|
||||
minimatch "^3.0.4"
|
||||
once "^1.3.0"
|
||||
path-is-absolute "^1.0.0"
|
||||
|
||||
glob@^7.0.3:
|
||||
glob@^7.0.0, glob@^7.0.3, glob@^7.1.3:
|
||||
version "7.2.0"
|
||||
resolved "https://registry.yarnpkg.com/glob/-/glob-7.2.0.tgz#d15535af7732e02e948f4c41628bd910293f6023"
|
||||
integrity sha512-lmLf6gtyrPq8tTjSmrO94wBeQbFR3HbLHbuyD69wuyQkImp2hWqMGB47OX65FBkPffO641IP9jWa1z4ivqG26Q==
|
||||
@ -5348,6 +5326,13 @@ is-core-module@^2.2.0:
|
||||
dependencies:
|
||||
has "^1.0.3"
|
||||
|
||||
is-core-module@^2.8.0:
|
||||
version "2.8.1"
|
||||
resolved "https://registry.yarnpkg.com/is-core-module/-/is-core-module-2.8.1.tgz#f59fdfca701d5879d0a6b100a40aa1560ce27211"
|
||||
integrity sha512-SdNCUs284hr40hFTFP6l0IfZ/RSrMXF3qgoRHd3/79unUTvrFO/JoXwkGm+5J/Oe3E/b5GsnG330uUNgRpu1PA==
|
||||
dependencies:
|
||||
has "^1.0.3"
|
||||
|
||||
is-data-descriptor@^0.1.4:
|
||||
version "0.1.4"
|
||||
resolved "https://registry.yarnpkg.com/is-data-descriptor/-/is-data-descriptor-0.1.4.tgz#0b5ee648388e2c860282e793f1856fec3f301b56"
|
||||
@ -6284,9 +6269,9 @@ nan@^2.12.1:
|
||||
integrity sha512-8ZtvEnA2c5aYCZYd1cvgdnU6cqwixRoYg70xPLWUws5ORTa/lnw+u4amixRS/Ac5U5mQVgp9pnlSUnbNWFaWZQ==
|
||||
|
||||
nanoid@^3.1.28, nanoid@^3.1.30:
|
||||
version "3.1.30"
|
||||
resolved "https://registry.yarnpkg.com/nanoid/-/nanoid-3.1.30.tgz#63f93cc548d2a113dc5dfbc63bfa09e2b9b64362"
|
||||
integrity sha512-zJpuPDwOv8D2zq2WRoMe1HsfZthVewpel9CAvTfc/2mBD1uUT/agc5f7GHGWXlYkFvi1mVxe4IjvP2HNrop7nQ==
|
||||
version "3.2.0"
|
||||
resolved "https://registry.yarnpkg.com/nanoid/-/nanoid-3.2.0.tgz#62667522da6673971cca916a6d3eff3f415ff80c"
|
||||
integrity sha512-fmsZYa9lpn69Ad5eDn7FMcnnSR+8R34W9qJEijxYhTbfOWzr22n1QxCMzXLK+ODyW2973V3Fux959iQoUxzUIA==
|
||||
|
||||
nanomatch@^1.2.9:
|
||||
version "1.2.13"
|
||||
@ -6737,7 +6722,7 @@ path-key@^3.0.0, path-key@^3.1.0:
|
||||
resolved "https://registry.yarnpkg.com/path-key/-/path-key-3.1.1.tgz#581f6ade658cbba65a0d3380de7753295054f375"
|
||||
integrity sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==
|
||||
|
||||
path-parse@^1.0.6:
|
||||
path-parse@^1.0.6, path-parse@^1.0.7:
|
||||
version "1.0.7"
|
||||
resolved "https://registry.yarnpkg.com/path-parse/-/path-parse-1.0.7.tgz#fbc114b60ca42b30d9daf5858e4bd68bbedb6735"
|
||||
integrity sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==
|
||||
@ -7885,7 +7870,16 @@ resolve-url@^0.2.1:
|
||||
resolved "https://registry.yarnpkg.com/resolve-url/-/resolve-url-0.2.1.tgz#2c637fe77c893afd2a663fe21aa9080068e2052a"
|
||||
integrity sha1-LGN/53yJOv0qZj/iGqkIAGjiBSo=
|
||||
|
||||
resolve@^1.1.6, resolve@^1.14.2, resolve@^1.3.2:
|
||||
resolve@^1.1.6:
|
||||
version "1.21.0"
|
||||
resolved "https://registry.yarnpkg.com/resolve/-/resolve-1.21.0.tgz#b51adc97f3472e6a5cf4444d34bc9d6b9037591f"
|
||||
integrity sha512-3wCbTpk5WJlyE4mSOtDLhqQmGFi0/TD9VPwmiolnk8U0wRgMEktqCXd3vy5buTO3tljvalNvKrjHEfrd2WpEKA==
|
||||
dependencies:
|
||||
is-core-module "^2.8.0"
|
||||
path-parse "^1.0.7"
|
||||
supports-preserve-symlinks-flag "^1.0.0"
|
||||
|
||||
resolve@^1.14.2, resolve@^1.3.2:
|
||||
version "1.20.0"
|
||||
resolved "https://registry.yarnpkg.com/resolve/-/resolve-1.20.0.tgz#629a013fb3f70755d6f0b7935cc1c2c5378b1975"
|
||||
integrity sha512-wENBPt4ySzg4ybFQW2TT1zMQucPK95HSh/nq2CFTZVOGut2+pQvSsgtda4d26YrYcr067wjbmzOG8byDPBX63A==
|
||||
@ -8218,9 +8212,9 @@ shell-quote@1.7.2:
|
||||
integrity sha512-mRz/m/JVscCrkMyPqHc/bczi3OQHkLTqXHEFu0zDhK/qfv3UcOA4SVmRCLmos4bhjr9ekVQubj/R7waKapmiQg==
|
||||
|
||||
shelljs@^0.8.4:
|
||||
version "0.8.4"
|
||||
resolved "https://registry.yarnpkg.com/shelljs/-/shelljs-0.8.4.tgz#de7684feeb767f8716b326078a8a00875890e3c2"
|
||||
integrity sha512-7gk3UZ9kOfPLIAbslLzyWeGiEqx9e3rxwZM0KE6EL8GlGwjym9Mrlx5/p33bWTu9YG6vcS4MBxYZDHYr5lr8BQ==
|
||||
version "0.8.5"
|
||||
resolved "https://registry.yarnpkg.com/shelljs/-/shelljs-0.8.5.tgz#de055408d8361bed66c669d2f000538ced8ee20c"
|
||||
integrity sha512-TiwcRcrkhHvbrZbnRcFYMLl30Dfov3HKqzp5tO5b4pt6G/SezKcYhmDg15zXVBswHmctSAQKznqNW2LO5tTDow==
|
||||
dependencies:
|
||||
glob "^7.0.0"
|
||||
interpret "^1.0.0"
|
||||
@ -8606,6 +8600,11 @@ supports-color@^8.0.0:
|
||||
dependencies:
|
||||
has-flag "^4.0.0"
|
||||
|
||||
supports-preserve-symlinks-flag@^1.0.0:
|
||||
version "1.0.0"
|
||||
resolved "https://registry.yarnpkg.com/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz#6eda4bd344a3c94aea376d4cc31bc77311039e09"
|
||||
integrity sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==
|
||||
|
||||
svg-parser@^2.0.2:
|
||||
version "2.0.4"
|
||||
resolved "https://registry.yarnpkg.com/svg-parser/-/svg-parser-2.0.4.tgz#fdc2e29e13951736140b76cb122c8ee6630eb6b5"
|
||||
|
@ -84,12 +84,12 @@
|
||||
<dependency>
|
||||
<groupId>com.google.http-client</groupId>
|
||||
<artifactId>google-http-client-jackson2</artifactId>
|
||||
<version>1.40.1</version>
|
||||
<version>1.41.2</version>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>mysql</groupId>
|
||||
<artifactId>mysql-connector-java</artifactId>
|
||||
<version>8.0.27</version>
|
||||
<version>8.0.28</version>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>org.jasypt</groupId>
|
||||
@ -99,7 +99,7 @@
|
||||
<dependency>
|
||||
<groupId>org.mariadb.jdbc</groupId>
|
||||
<artifactId>mariadb-java-client</artifactId>
|
||||
<version>2.7.4</version>
|
||||
<version>2.7.5</version>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>org.xerial</groupId>
|
||||
|
@ -1,3 +1,4 @@
|
||||
|
||||
package com.google.refine.extension.database;
|
||||
|
||||
import java.io.File;
|
||||
@ -45,10 +46,11 @@ public class DBExtensionTestUtils {
|
||||
private Map<Integer, Integer> mncMap;
|
||||
private Map<Integer, Integer> mccMap;
|
||||
|
||||
|
||||
/**
|
||||
* Create Test Table with one row of Data
|
||||
* @param dbConfig DatabaseConfiguration to test
|
||||
*
|
||||
* @param dbConfig
|
||||
* DatabaseConfiguration to test
|
||||
* @param tableName
|
||||
* @throws DatabaseServiceException
|
||||
* @throws SQLException
|
||||
@ -82,7 +84,6 @@ public class DBExtensionTestUtils {
|
||||
+ " CITY VARCHAR (20) NOT NULL,"
|
||||
+ " PRIMARY KEY (ID) );";
|
||||
|
||||
|
||||
stmt.executeUpdate(createSQL);
|
||||
// System.out.println("Create Table Result::" + createResult);
|
||||
|
||||
@ -114,7 +115,6 @@ public class DBExtensionTestUtils {
|
||||
|
||||
}
|
||||
|
||||
|
||||
public static void initTestData(DatabaseConfiguration dbConfig)
|
||||
throws DatabaseServiceException, SQLException {
|
||||
|
||||
@ -145,7 +145,6 @@ public class DBExtensionTestUtils {
|
||||
+ " CITY VARCHAR (20) NOT NULL,"
|
||||
+ " PRIMARY KEY (ID) );";
|
||||
|
||||
|
||||
stmt.executeUpdate(createSQL);
|
||||
// System.out.println("Create Table Result::" + createResult);
|
||||
|
||||
@ -180,8 +179,8 @@ public class DBExtensionTestUtils {
|
||||
}
|
||||
|
||||
/**
|
||||
* CREATE test data in MySQL
|
||||
* Table name: test_data
|
||||
* CREATE test data in MySQL Table name: test_data
|
||||
*
|
||||
* @param sampleSize
|
||||
* @param batchSize
|
||||
* @throws DatabaseServiceException
|
||||
@ -223,7 +222,6 @@ public class DBExtensionTestUtils {
|
||||
System.out.println("Truncate Table Result::" + result);
|
||||
truncateStmt.close();
|
||||
|
||||
|
||||
conn.setAutoCommit(false);
|
||||
|
||||
PreparedStatement stmt = conn.prepareStatement(insertTableSQL);
|
||||
@ -300,7 +298,6 @@ public class DBExtensionTestUtils {
|
||||
System.out.println("Truncate Table Result::" + result);
|
||||
truncateStmt.close();
|
||||
|
||||
|
||||
conn.setAutoCommit(false);
|
||||
|
||||
PreparedStatement stmt = conn.prepareStatement(insertTableSQL);
|
||||
@ -341,8 +338,6 @@ public class DBExtensionTestUtils {
|
||||
return "" + n;
|
||||
}
|
||||
|
||||
|
||||
|
||||
private int getMNC() {
|
||||
|
||||
return mncMap.get(rand.nextInt(3));
|
||||
@ -376,7 +371,6 @@ public class DBExtensionTestUtils {
|
||||
// testUtil.generateMySQLTestData();
|
||||
}
|
||||
|
||||
|
||||
public static void cleanUpTestData(DatabaseConfiguration dbConfig) {
|
||||
Statement stmt = null;
|
||||
Connection conn = null;
|
||||
|
@ -53,7 +53,6 @@ public class DBExtensionTests {
|
||||
protected final String DEFAULT_PGSQL_PASSWORD = "";
|
||||
protected final String DEFAULT_PGSQL_DB_NAME = "testdb";
|
||||
|
||||
|
||||
protected final String MARIA_DB_NAME = "mariadb";
|
||||
protected final String DEFAULT_MARIADB_HOST = "127.0.0.1";
|
||||
protected final String DEFAULT_MARIADB_PORT = "3306";
|
||||
|
@ -1,5 +1,5 @@
|
||||
package com.google.refine.extension.database;
|
||||
|
||||
package com.google.refine.extension.database;
|
||||
|
||||
import static org.mockito.Mockito.when;
|
||||
|
||||
@ -34,8 +34,6 @@ import com.google.refine.io.FileProjectManager;
|
||||
import com.google.refine.model.Project;
|
||||
import com.google.refine.util.ParsingUtilities;
|
||||
|
||||
|
||||
|
||||
@Test(groups = { "requiresMySQL" })
|
||||
public class DatabaseImportControllerTest extends DBExtensionTests {
|
||||
|
||||
@ -90,7 +88,6 @@ public class DatabaseImportControllerTest extends DBExtensionTests{
|
||||
// options = null;
|
||||
}
|
||||
|
||||
|
||||
@Test
|
||||
public void testDoGet() {
|
||||
StringWriter sw = new StringWriter();
|
||||
@ -110,7 +107,6 @@ public class DatabaseImportControllerTest extends DBExtensionTests{
|
||||
Assert.assertEquals(code, "error");
|
||||
Assert.assertEquals(message, "GET not implemented");
|
||||
|
||||
|
||||
} catch (Exception e) {
|
||||
// TODO Auto-generated catch block
|
||||
e.printStackTrace();
|
||||
@ -139,8 +135,6 @@ public class DatabaseImportControllerTest extends DBExtensionTests{
|
||||
Assert.assertEquals(message, "No such sub command");
|
||||
}
|
||||
|
||||
|
||||
|
||||
@Test
|
||||
public void testDoPostInitializeParser() throws ServletException, IOException {
|
||||
|
||||
@ -174,7 +168,6 @@ public class DatabaseImportControllerTest extends DBExtensionTests{
|
||||
+ jobId + "&subCommand=parse-preview");
|
||||
when(response.getWriter()).thenReturn(pw);
|
||||
|
||||
|
||||
when(request.getParameter("databaseType")).thenReturn(testDbConfig.getDatabaseType());
|
||||
when(request.getParameter("databaseServer")).thenReturn(testDbConfig.getDatabaseHost());
|
||||
when(request.getParameter("databasePort")).thenReturn("" + testDbConfig.getDatabasePort());
|
||||
@ -207,7 +200,6 @@ public class DatabaseImportControllerTest extends DBExtensionTests{
|
||||
+ jobId + "&subCommand=create-project");
|
||||
when(response.getWriter()).thenReturn(pw);
|
||||
|
||||
|
||||
when(request.getParameter("databaseType")).thenReturn(testDbConfig.getDatabaseType());
|
||||
when(request.getParameter("databaseServer")).thenReturn(testDbConfig.getDatabaseHost());
|
||||
when(request.getParameter("databasePort")).thenReturn("" + testDbConfig.getDatabasePort());
|
||||
@ -217,7 +209,6 @@ public class DatabaseImportControllerTest extends DBExtensionTests{
|
||||
when(request.getParameter("query")).thenReturn(query);
|
||||
when(request.getParameter("options")).thenReturn(JSON_OPTION);
|
||||
|
||||
|
||||
SUT.doPost(request, response);
|
||||
|
||||
String result = sw.getBuffer().toString().trim();
|
||||
@ -249,10 +240,8 @@ public class DatabaseImportControllerTest extends DBExtensionTests{
|
||||
|
||||
// testTable = mySqlTestTable;
|
||||
|
||||
|
||||
DatabaseService.DBType.registerDatabase(MySQLDatabaseService.DB_NAME, MySQLDatabaseService.getInstance());
|
||||
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
@ -1,5 +1,5 @@
|
||||
package com.google.refine.extension.database;
|
||||
|
||||
package com.google.refine.extension.database;
|
||||
|
||||
import java.sql.Connection;
|
||||
import java.util.List;
|
||||
@ -18,22 +18,17 @@ import com.google.refine.extension.database.model.DatabaseRow;
|
||||
import com.google.refine.extension.database.mysql.MySQLDatabaseService;
|
||||
import com.google.refine.extension.database.pgsql.PgSQLDatabaseService;
|
||||
|
||||
|
||||
|
||||
|
||||
public class DatabaseServiceTest extends DBExtensionTests {
|
||||
|
||||
private DatabaseConfiguration testDbConfig;
|
||||
private String testTable;
|
||||
|
||||
|
||||
@BeforeTest
|
||||
@Parameters({ "mySqlDbName", "mySqlDbHost", "mySqlDbPort", "mySqlDbUser", "mySqlDbPassword", "mySqlTestTable" })
|
||||
public void beforeTest(@Optional(DEFAULT_MYSQL_DB_NAME) String mySqlDbName, @Optional(DEFAULT_MYSQL_HOST) String mySqlDbHost,
|
||||
@Optional(DEFAULT_MYSQL_PORT) String mySqlDbPort, @Optional(DEFAULT_MYSQL_USER) String mySqlDbUser,
|
||||
@Optional(DEFAULT_MYSQL_PASSWORD) String mySqlDbPassword, @Optional(DEFAULT_TEST_TABLE) String mySqlTestTable) {
|
||||
|
||||
|
||||
testDbConfig = new DatabaseConfiguration();
|
||||
testDbConfig.setDatabaseHost(mySqlDbHost);
|
||||
testDbConfig.setDatabaseName(mySqlDbName);
|
||||
@ -52,8 +47,6 @@ public class DatabaseServiceTest extends DBExtensionTests{
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
@Test
|
||||
public void testGetDatabaseUrl() {
|
||||
DatabaseService dbService = DatabaseService.get(testDbConfig.getDatabaseType());
|
||||
@ -62,7 +55,6 @@ public class DatabaseServiceTest extends DBExtensionTests{
|
||||
Assert.assertEquals(dbUrl, DBExtensionTestUtils.getJDBCUrl(testDbConfig));
|
||||
}
|
||||
|
||||
|
||||
@Test(groups = { "requiresPgSQL" })
|
||||
public void testGetPgSQLDBService() {
|
||||
DatabaseService dbService = DatabaseService.get(PgSQLDatabaseService.DB_NAME);
|
||||
|
@ -1,3 +1,4 @@
|
||||
|
||||
package com.google.refine.extension.database;
|
||||
|
||||
import java.sql.SQLException;
|
||||
|
@ -1,3 +1,4 @@
|
||||
|
||||
package com.google.refine.extension.database;
|
||||
|
||||
import java.sql.SQLException;
|
||||
|
@ -1,3 +1,4 @@
|
||||
|
||||
package com.google.refine.extension.database;
|
||||
|
||||
import java.sql.SQLException;
|
||||
|
@ -1,3 +1,4 @@
|
||||
|
||||
package com.google.refine.extension.database;
|
||||
|
||||
import java.sql.SQLException;
|
||||
|
@ -1,3 +1,4 @@
|
||||
|
||||
package com.google.refine.extension.database;
|
||||
|
||||
import org.testng.Assert;
|
||||
|
@ -27,11 +27,9 @@ import com.google.refine.extension.database.DatabaseService;
|
||||
import com.google.refine.extension.database.mysql.MySQLDatabaseService;
|
||||
import com.google.refine.util.ParsingUtilities;
|
||||
|
||||
|
||||
@Test(groups = { "requiresMySQL" })
|
||||
public class ConnectCommandTest extends DBExtensionTests {
|
||||
|
||||
|
||||
@Mock
|
||||
private HttpServletRequest request;
|
||||
|
||||
@ -41,7 +39,6 @@ public class ConnectCommandTest extends DBExtensionTests {
|
||||
private DatabaseConfiguration testDbConfig;
|
||||
// private String testTable;
|
||||
|
||||
|
||||
@BeforeTest
|
||||
@Parameters({ "mySqlDbName", "mySqlDbHost", "mySqlDbPort", "mySqlDbUser", "mySqlDbPassword", "mySqlTestTable" })
|
||||
public void beforeTest(@Optional(DEFAULT_MYSQL_DB_NAME) String mySqlDbName, @Optional(DEFAULT_MYSQL_HOST) String mySqlDbHost,
|
||||
@ -66,7 +63,6 @@ public class ConnectCommandTest extends DBExtensionTests {
|
||||
|
||||
}
|
||||
|
||||
|
||||
@Test
|
||||
public void testDoPost() throws IOException, ServletException {
|
||||
|
||||
@ -106,7 +102,8 @@ public class ConnectCommandTest extends DBExtensionTests {
|
||||
|
||||
connectCommand.doPost(request, response);
|
||||
Assert.assertEquals(
|
||||
ParsingUtilities.mapper.readValue("{\"code\":\"error\",\"message\":\"Missing or invalid csrf_token parameter\"}", ObjectNode.class),
|
||||
ParsingUtilities.mapper.readValue("{\"code\":\"error\",\"message\":\"Missing or invalid csrf_token parameter\"}",
|
||||
ObjectNode.class),
|
||||
ParsingUtilities.mapper.readValue(sw.toString(), ObjectNode.class));
|
||||
}
|
||||
|
||||
|
@ -1,3 +1,4 @@
|
||||
|
||||
package com.google.refine.extension.database.cmd;
|
||||
|
||||
import static org.mockito.Mockito.when;
|
||||
@ -35,11 +36,9 @@ public class ExecuteQueryCommandTest extends DBExtensionTests {
|
||||
@Mock
|
||||
private HttpServletResponse response;
|
||||
|
||||
|
||||
private DatabaseConfiguration testDbConfig;
|
||||
private String testTable;
|
||||
|
||||
|
||||
@BeforeTest
|
||||
@Parameters({ "mySqlDbName", "mySqlDbHost", "mySqlDbPort", "mySqlDbUser", "mySqlDbPassword", "mySqlTestTable" })
|
||||
public void beforeTest(@Optional(DEFAULT_MYSQL_DB_NAME) String mySqlDbName, @Optional(DEFAULT_MYSQL_HOST) String mySqlDbHost,
|
||||
@ -75,7 +74,6 @@ public class ExecuteQueryCommandTest extends DBExtensionTests {
|
||||
when(request.getParameter("queryString")).thenReturn("SELECT count(*) FROM " + testTable);
|
||||
when(request.getParameter("csrf_token")).thenReturn(Command.csrfFactory.getFreshToken());
|
||||
|
||||
|
||||
StringWriter sw = new StringWriter();
|
||||
|
||||
PrintWriter pw = new PrintWriter(sw);
|
||||
@ -105,7 +103,8 @@ public class ExecuteQueryCommandTest extends DBExtensionTests {
|
||||
|
||||
connectCommand.doPost(request, response);
|
||||
Assert.assertEquals(
|
||||
ParsingUtilities.mapper.readValue("{\"code\":\"error\",\"message\":\"Missing or invalid csrf_token parameter\"}", ObjectNode.class),
|
||||
ParsingUtilities.mapper.readValue("{\"code\":\"error\",\"message\":\"Missing or invalid csrf_token parameter\"}",
|
||||
ObjectNode.class),
|
||||
ParsingUtilities.mapper.readValue(sw.toString(), ObjectNode.class));
|
||||
}
|
||||
}
|
||||
|
@ -1,3 +1,4 @@
|
||||
|
||||
package com.google.refine.extension.database.cmd;
|
||||
|
||||
import static org.mockito.Mockito.when;
|
||||
@ -60,7 +61,6 @@ public class SavedConnectionCommandTest extends DBExtensionTests{
|
||||
|
||||
// private String JSON_OPTION = "{\"mode\":\"row-based\"}}";
|
||||
|
||||
|
||||
// System under test
|
||||
private SavedConnectionCommand SUT = null;
|
||||
|
||||
@ -115,8 +115,6 @@ public class SavedConnectionCommandTest extends DBExtensionTests{
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
private void saveDatabaseConfiguration(String savedDbName) {
|
||||
|
||||
when(request.getParameter("connectionName")).thenReturn(savedDbName);
|
||||
@ -182,7 +180,6 @@ public class SavedConnectionCommandTest extends DBExtensionTests{
|
||||
// add saved connection
|
||||
saveDatabaseConfiguration(testDbName);
|
||||
|
||||
|
||||
when(request.getParameter("connectionName")).thenReturn(testDbName);
|
||||
when(request.getParameter("databaseType")).thenReturn(MySQLDatabaseService.DB_NAME);
|
||||
when(request.getParameter("databaseServer")).thenReturn(testDbConfig.getDatabaseHost());
|
||||
@ -216,7 +213,6 @@ public class SavedConnectionCommandTest extends DBExtensionTests{
|
||||
String testDbName = "testLocalDb";
|
||||
saveDatabaseConfiguration(testDbName);
|
||||
|
||||
|
||||
StringWriter sw = new StringWriter();
|
||||
PrintWriter pw = new PrintWriter(sw);
|
||||
|
||||
@ -251,7 +247,6 @@ public class SavedConnectionCommandTest extends DBExtensionTests{
|
||||
String testDbName = "testLocalDb";
|
||||
saveDatabaseConfiguration(testDbName);
|
||||
|
||||
|
||||
StringWriter sw = new StringWriter();
|
||||
PrintWriter pw = new PrintWriter(sw);
|
||||
|
||||
@ -277,7 +272,6 @@ public class SavedConnectionCommandTest extends DBExtensionTests{
|
||||
String testDbName = "testLocalDb";
|
||||
saveDatabaseConfiguration(testDbName);
|
||||
|
||||
|
||||
StringWriter sw = new StringWriter();
|
||||
PrintWriter pw = new PrintWriter(sw);
|
||||
|
||||
@ -292,7 +286,6 @@ public class SavedConnectionCommandTest extends DBExtensionTests{
|
||||
|
||||
Assert.assertNotNull(json);
|
||||
|
||||
|
||||
} catch (Exception e) {
|
||||
// TODO Auto-generated catch block
|
||||
e.printStackTrace();
|
||||
@ -301,6 +294,7 @@ public class SavedConnectionCommandTest extends DBExtensionTests{
|
||||
|
||||
/**
|
||||
* Added to check XSS invalid tokens
|
||||
*
|
||||
* @throws IOException
|
||||
* @throws ServletException
|
||||
*/
|
||||
@ -335,9 +329,9 @@ public class SavedConnectionCommandTest extends DBExtensionTests{
|
||||
|
||||
SUT.doPost(request, response);
|
||||
Assert.assertEquals(
|
||||
ParsingUtilities.mapper.readValue("{\"code\":\"error\",\"message\":\"Missing or invalid csrf_token parameter\"}", ObjectNode.class),
|
||||
ParsingUtilities.mapper.readValue("{\"code\":\"error\",\"message\":\"Missing or invalid csrf_token parameter\"}",
|
||||
ObjectNode.class),
|
||||
ParsingUtilities.mapper.readValue(sw.toString(), ObjectNode.class));
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
@ -1,3 +1,4 @@
|
||||
|
||||
package com.google.refine.extension.database.cmd;
|
||||
|
||||
import static org.mockito.Mockito.when;
|
||||
@ -26,7 +27,6 @@ import com.google.refine.extension.database.DatabaseService;
|
||||
import com.google.refine.extension.database.mysql.MySQLDatabaseService;
|
||||
import com.google.refine.util.ParsingUtilities;
|
||||
|
||||
|
||||
@Test(groups = { "requiresMySQL" })
|
||||
public class TestConnectCommandTest extends DBExtensionTests {
|
||||
|
||||
@ -39,7 +39,6 @@ public class TestConnectCommandTest extends DBExtensionTests{
|
||||
private DatabaseConfiguration testDbConfig;
|
||||
// private String testTable;
|
||||
|
||||
|
||||
@BeforeTest
|
||||
@Parameters({ "mySqlDbName", "mySqlDbHost", "mySqlDbPort", "mySqlDbUser", "mySqlDbPassword", "mySqlTestTable" })
|
||||
public void beforeTest(@Optional(DEFAULT_MYSQL_DB_NAME) String mySqlDbName, @Optional(DEFAULT_MYSQL_HOST) String mySqlDbHost,
|
||||
@ -64,8 +63,6 @@ public class TestConnectCommandTest extends DBExtensionTests{
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
@Test
|
||||
public void testDoPost() throws IOException, ServletException {
|
||||
|
||||
@ -77,7 +74,6 @@ public class TestConnectCommandTest extends DBExtensionTests{
|
||||
when(request.getParameter("initialDatabase")).thenReturn(testDbConfig.getDatabaseName());
|
||||
when(request.getParameter("csrf_token")).thenReturn(Command.csrfFactory.getFreshToken());
|
||||
|
||||
|
||||
StringWriter sw = new StringWriter();
|
||||
|
||||
PrintWriter pw = new PrintWriter(sw);
|
||||
@ -105,7 +101,8 @@ public class TestConnectCommandTest extends DBExtensionTests{
|
||||
|
||||
connectCommand.doPost(request, response);
|
||||
Assert.assertEquals(
|
||||
ParsingUtilities.mapper.readValue("{\"code\":\"error\",\"message\":\"Missing or invalid csrf_token parameter\"}", ObjectNode.class),
|
||||
ParsingUtilities.mapper.readValue("{\"code\":\"error\",\"message\":\"Missing or invalid csrf_token parameter\"}",
|
||||
ObjectNode.class),
|
||||
ParsingUtilities.mapper.readValue(sw.toString(), ObjectNode.class));
|
||||
}
|
||||
|
||||
|
@ -1,3 +1,4 @@
|
||||
|
||||
package com.google.refine.extension.database.cmd;
|
||||
|
||||
import static org.mockito.Mockito.when;
|
||||
@ -35,11 +36,9 @@ public class TestQueryCommandTest extends DBExtensionTests {
|
||||
@Mock
|
||||
private HttpServletResponse response;
|
||||
|
||||
|
||||
private DatabaseConfiguration testDbConfig;
|
||||
private String testTable;
|
||||
|
||||
|
||||
@BeforeTest
|
||||
@Parameters({ "mySqlDbName", "mySqlDbHost", "mySqlDbPort", "mySqlDbUser", "mySqlDbPassword", "mySqlTestTable" })
|
||||
public void beforeTest(@Optional(DEFAULT_MYSQL_DB_NAME) String mySqlDbName, @Optional(DEFAULT_MYSQL_HOST) String mySqlDbHost,
|
||||
@ -63,7 +62,6 @@ public class TestQueryCommandTest extends DBExtensionTests {
|
||||
|
||||
}
|
||||
|
||||
|
||||
@Test
|
||||
public void testDoPost() throws IOException, ServletException {
|
||||
|
||||
@ -106,7 +104,8 @@ public class TestQueryCommandTest extends DBExtensionTests {
|
||||
|
||||
connectCommand.doPost(request, response);
|
||||
Assert.assertEquals(
|
||||
ParsingUtilities.mapper.readValue("{\"code\":\"error\",\"message\":\"Missing or invalid csrf_token parameter\"}", ObjectNode.class),
|
||||
ParsingUtilities.mapper.readValue("{\"code\":\"error\",\"message\":\"Missing or invalid csrf_token parameter\"}",
|
||||
ObjectNode.class),
|
||||
ParsingUtilities.mapper.readValue(sw.toString(), ObjectNode.class));
|
||||
}
|
||||
|
||||
|
@ -1,3 +1,4 @@
|
||||
|
||||
package com.google.refine.extension.database.mariadb;
|
||||
|
||||
import java.sql.Connection;
|
||||
@ -18,11 +19,8 @@ import com.google.refine.extension.database.DatabaseServiceException;
|
||||
@Test(groups = { "requiresMariaDB" })
|
||||
public class MariaDBConnectionManagerTest extends DBExtensionTests {
|
||||
|
||||
|
||||
|
||||
private DatabaseConfiguration testDbConfig;
|
||||
|
||||
|
||||
@BeforeTest
|
||||
@Parameters({ "mariadbDbName", "mariadbDbHost", "mariadbDbPort", "mariadbDbUser", "mariadbDbPassword", "mariaTestTable" })
|
||||
public void beforeTest(@Optional(DEFAULT_MARIADB_NAME) String mariaDbName, @Optional(DEFAULT_MARIADB_HOST) String mariaDbHost,
|
||||
@ -47,7 +45,6 @@ public class MariaDBConnectionManagerTest extends DBExtensionTests {
|
||||
|
||||
}
|
||||
|
||||
|
||||
@Test
|
||||
public void testTestConnection() throws DatabaseServiceException {
|
||||
boolean conn = MariaDBConnectionManager.getInstance().testConnection(testDbConfig);
|
||||
|
@ -1,3 +1,4 @@
|
||||
|
||||
package com.google.refine.extension.database.mariadb;
|
||||
|
||||
import java.sql.Connection;
|
||||
@ -22,13 +23,10 @@ import com.google.refine.extension.database.model.DatabaseRow;
|
||||
@Test(groups = { "requiresMariaDB" })
|
||||
public class MariaDBDatabaseServiceTest extends DBExtensionTests {
|
||||
|
||||
|
||||
|
||||
private DatabaseConfiguration testDbConfig;
|
||||
|
||||
private String testTable;
|
||||
|
||||
|
||||
@BeforeTest
|
||||
@Parameters({ "mariadbDbName", "mariadbDbHost", "mariadbDbPort", "mariadbDbUser", "mariadbDbPassword", "mariadbTestTable" })
|
||||
public void beforeTest(@Optional(DEFAULT_MARIADB_NAME) String mariaDbName, @Optional(DEFAULT_MARIADB_HOST) String mariaDbHost,
|
||||
@ -129,5 +127,4 @@ public class MariaDBDatabaseServiceTest extends DBExtensionTests{
|
||||
Assert.assertNotNull(dbColumns);
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
@ -1,3 +1,4 @@
|
||||
|
||||
package com.google.refine.extension.database.mysql;
|
||||
|
||||
import java.sql.Connection;
|
||||
@ -20,7 +21,6 @@ public class MySQLConnectionManagerTest extends DBExtensionTests {
|
||||
|
||||
private DatabaseConfiguration testDbConfig;
|
||||
|
||||
|
||||
@BeforeTest
|
||||
@Parameters({ "mySqlDbName", "mySqlDbHost", "mySqlDbPort", "mySqlDbUser", "mySqlDbPassword", "mySqlTestTable" })
|
||||
public void beforeTest(@Optional(DEFAULT_MYSQL_DB_NAME) String mySqlDbName, @Optional(DEFAULT_MYSQL_HOST) String mySqlDbHost,
|
||||
@ -45,7 +45,6 @@ public class MySQLConnectionManagerTest extends DBExtensionTests {
|
||||
|
||||
}
|
||||
|
||||
|
||||
@Test
|
||||
public void testTestConnection() throws DatabaseServiceException {
|
||||
|
||||
|
@ -1,3 +1,4 @@
|
||||
|
||||
package com.google.refine.extension.database.mysql;
|
||||
|
||||
import java.sql.Connection;
|
||||
@ -19,7 +20,6 @@ import com.google.refine.extension.database.model.DatabaseColumn;
|
||||
import com.google.refine.extension.database.model.DatabaseInfo;
|
||||
import com.google.refine.extension.database.model.DatabaseRow;
|
||||
|
||||
|
||||
@Test(groups = { "requiresMySQL" })
|
||||
public class MySQLDatabaseServiceTest extends DBExtensionTests {
|
||||
|
||||
@ -50,7 +50,6 @@ public class MySQLDatabaseServiceTest extends DBExtensionTests{
|
||||
|
||||
}
|
||||
|
||||
|
||||
@Test
|
||||
public void testGetDatabaseUrl() {
|
||||
MySQLDatabaseService pgSqlService = (MySQLDatabaseService) DatabaseService.get(MySQLDatabaseService.DB_NAME);
|
||||
@ -60,7 +59,6 @@ public class MySQLDatabaseServiceTest extends DBExtensionTests{
|
||||
Assert.assertEquals(dbUrl, DBExtensionTestUtils.getJDBCUrl(testDbConfig));
|
||||
}
|
||||
|
||||
|
||||
@Test
|
||||
public void testGetConnection() throws DatabaseServiceException {
|
||||
MySQLDatabaseService pgSqlService = (MySQLDatabaseService) DatabaseService.get(MySQLDatabaseService.DB_NAME);
|
||||
@ -128,6 +126,4 @@ public class MySQLDatabaseServiceTest extends DBExtensionTests{
|
||||
Assert.assertNotNull(dbColumns);
|
||||
}
|
||||
|
||||
|
||||
|
||||
}
|
||||
|
@ -1,3 +1,4 @@
|
||||
|
||||
package com.google.refine.extension.database.pgsql;
|
||||
|
||||
import java.sql.Connection;
|
||||
@ -15,13 +16,11 @@ import com.google.refine.extension.database.DatabaseConfiguration;
|
||||
import com.google.refine.extension.database.DatabaseService;
|
||||
import com.google.refine.extension.database.DatabaseServiceException;
|
||||
|
||||
|
||||
@Test(groups = { "requiresPgSQL" })
|
||||
public class PgSQLConnectionManagerTest extends DBExtensionTests {
|
||||
|
||||
private DatabaseConfiguration testDbConfig;
|
||||
|
||||
|
||||
@BeforeTest
|
||||
@Parameters({ "pgSqlDbName", "pgSqlDbHost", "pgSqlDbPort", "pgSqlDbUser", "pgSqlDbPassword", "pgSqlTestTable" })
|
||||
public void beforeTest(@Optional(DEFAULT_PGSQL_DB_NAME) String pgSqlDbName, @Optional(DEFAULT_PGSQL_HOST) String pgSqlDbHost,
|
||||
@ -46,8 +45,6 @@ public class PgSQLConnectionManagerTest extends DBExtensionTests {
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
@Test
|
||||
public void testTestConnection() throws DatabaseServiceException {
|
||||
|
||||
|
@ -1,3 +1,4 @@
|
||||
|
||||
package com.google.refine.extension.database.pgsql;
|
||||
|
||||
import java.sql.Connection;
|
||||
@ -25,7 +26,6 @@ public class PgSQLDatabaseServiceTest extends DBExtensionTests{
|
||||
private DatabaseConfiguration testDbConfig;
|
||||
private String testTable;
|
||||
|
||||
|
||||
@BeforeTest
|
||||
@Parameters({ "pgSqlDbName", "pgSqlDbHost", "pgSqlDbPort", "pgSqlDbUser", "pgSqlDbPassword", "pgSqlTestTable" })
|
||||
public void beforeTest(@Optional(DEFAULT_PGSQL_DB_NAME) String pgSqlDbName, @Optional(DEFAULT_PGSQL_HOST) String pgSqlDbHost,
|
||||
@ -48,8 +48,6 @@ public class PgSQLDatabaseServiceTest extends DBExtensionTests{
|
||||
DatabaseService.DBType.registerDatabase(PgSQLDatabaseService.DB_NAME, PgSQLDatabaseService.getInstance());
|
||||
}
|
||||
|
||||
|
||||
|
||||
@Test
|
||||
public void testGetDatabaseUrl() {
|
||||
PgSQLDatabaseService pgSqlService = (PgSQLDatabaseService) DatabaseService.get(PgSQLDatabaseService.DB_NAME);
|
||||
@ -59,7 +57,6 @@ public class PgSQLDatabaseServiceTest extends DBExtensionTests{
|
||||
Assert.assertEquals(dbUrl, DBExtensionTestUtils.getJDBCUrl(testDbConfig));
|
||||
}
|
||||
|
||||
|
||||
@Test
|
||||
public void testGetConnection() throws DatabaseServiceException {
|
||||
|
||||
@ -131,5 +128,4 @@ public class PgSQLDatabaseServiceTest extends DBExtensionTests{
|
||||
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
@ -78,6 +78,7 @@ public class RefineDbServletStub extends RefineServlet {
|
||||
// -------------------helper methods--------------
|
||||
/**
|
||||
* Helper method for inserting a mock object
|
||||
*
|
||||
* @param commandName
|
||||
* @param command
|
||||
*/
|
||||
@ -87,6 +88,7 @@ public class RefineDbServletStub extends RefineServlet {
|
||||
|
||||
/**
|
||||
* Helper method for clearing up after testing
|
||||
*
|
||||
* @param commandName
|
||||
*/
|
||||
public void removeCommand(String commandName) {
|
||||
|
@ -80,7 +80,7 @@
|
||||
<dependency>
|
||||
<groupId>com.google.apis</groupId>
|
||||
<artifactId>google-api-services-drive</artifactId>
|
||||
<version>v3-rev20211107-1.32.1</version>
|
||||
<version>v3-rev20220110-1.32.1</version>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>com.google.apis</groupId>
|
||||
|
@ -1,3 +1,4 @@
|
||||
|
||||
package com.google.refine.extension.gdata;
|
||||
|
||||
import com.google.refine.ProjectManager;
|
||||
|
@ -1,3 +1,4 @@
|
||||
|
||||
package com.google.refine.extension.gdata;
|
||||
|
||||
import static org.mockito.Mockito.mock;
|
||||
|
@ -1,3 +1,4 @@
|
||||
|
||||
package com.google.refine.extension.gdata;
|
||||
|
||||
import static org.mockito.Mockito.mock;
|
||||
@ -20,7 +21,6 @@ import com.fasterxml.jackson.databind.node.ObjectNode;
|
||||
import com.google.refine.commands.Command;
|
||||
import com.google.refine.util.ParsingUtilities;
|
||||
|
||||
|
||||
class UploadCommandStub extends UploadCommand {
|
||||
|
||||
public byte[] getIcon() throws IOException {
|
||||
@ -29,12 +29,12 @@ class UploadCommandStub extends UploadCommand {
|
||||
}
|
||||
|
||||
public class UploadCommandTest {
|
||||
|
||||
protected HttpServletRequest request = null;
|
||||
protected HttpServletResponse response = null;
|
||||
protected Command command = null;
|
||||
protected StringWriter writer = null;
|
||||
|
||||
|
||||
@BeforeMethod
|
||||
public void setUpRequestResponse() {
|
||||
request = mock(HttpServletRequest.class);
|
||||
@ -52,7 +52,8 @@ public class UploadCommandTest {
|
||||
public void testCsrfProtection() throws ServletException, IOException {
|
||||
command.doPost(request, response);
|
||||
Assert.assertEquals(
|
||||
ParsingUtilities.mapper.readValue("{\"code\":\"error\",\"message\":\"Missing or invalid csrf_token parameter\"}", ObjectNode.class),
|
||||
ParsingUtilities.mapper.readValue("{\"code\":\"error\",\"message\":\"Missing or invalid csrf_token parameter\"}",
|
||||
ObjectNode.class),
|
||||
ParsingUtilities.mapper.readValue(writer.toString(), ObjectNode.class));
|
||||
|
||||
}
|
||||
|
@ -1,3 +1,4 @@
|
||||
|
||||
package com.google.refine.jython;
|
||||
|
||||
import java.util.Properties;
|
||||
|
@ -1,3 +1,4 @@
|
||||
|
||||
package com.google.refine.jython;
|
||||
|
||||
import java.io.File;
|
||||
|
@ -1,3 +1,4 @@
|
||||
|
||||
package org.openrefine.phonetic.keyers;
|
||||
|
||||
import static org.testng.Assert.assertEquals;
|
||||
|
@ -1,3 +1,4 @@
|
||||
|
||||
package org.openrefine.phonetic.keyers;
|
||||
|
||||
import static org.testng.Assert.assertEquals;
|
||||
@ -7,6 +8,7 @@ import org.testng.annotations.Test;
|
||||
import com.google.refine.clustering.binning.Keyer;
|
||||
|
||||
public class DaitchMokotoffKeyerTest {
|
||||
|
||||
protected Keyer keyer = new DaitchMokotoffKeyer();
|
||||
|
||||
@Test
|
||||
@ -19,7 +21,6 @@ public class DaitchMokotoffKeyerTest {
|
||||
assertEquals(keyer.key("Éléonore"), "086900");
|
||||
}
|
||||
|
||||
|
||||
@Test
|
||||
public void testEmpty() {
|
||||
assertEquals(keyer.key(""), "000000");
|
||||
|
@ -5,7 +5,7 @@
|
||||
<groupId>org.openrefine</groupId>
|
||||
<artifactId>sample</artifactId>
|
||||
<packaging>jar</packaging>
|
||||
<version>3.0-SNAPSHOT</version>
|
||||
<version>3.6-SNAPSHOT</version>
|
||||
|
||||
<name>OpenRefine - Sample extension</name>
|
||||
<description>Example extension provided for demonstration purposes</description>
|
||||
|
@ -58,12 +58,14 @@ function init() {
|
||||
"scripts/ajv.min.js",
|
||||
"scripts/wikidata-manifest-v1.0.js",
|
||||
"scripts/wikibase-manifest-schema-v1.js",
|
||||
"scripts/wikibase-manifest-schema-v2.js",
|
||||
"scripts/wikibase-manager.js",
|
||||
"scripts/menu-bar-extension.js",
|
||||
"scripts/warningsrenderer.js",
|
||||
"scripts/langsuggest.js",
|
||||
"scripts/bettersuggest.js",
|
||||
"scripts/previewrenderer.js",
|
||||
"scripts/wikibase-suggest.js",
|
||||
"scripts/schema-alignment.js",
|
||||
"scripts/wikidata-extension-manager.js",
|
||||
"scripts/dialogs/manage-account-dialog.js",
|
||||
|
@ -27,7 +27,7 @@
|
||||
"wikibase-addition/cancel": "Cancel",
|
||||
"wikibase-addition/invalid-manifest": "Invalid Wikibase manifest.",
|
||||
"wikibase-schema/dialog-header": "Align to Wikibase",
|
||||
"wikibase-schema/dialog-explanation": "You are currently working against <a href=\"$1\" target=\"_blank\">$2</a>. You should have your data reconciled to reconciliation services linked to $2 (such as <a href=\"$3\" target=\"_blank\">$3</a>) first. The schema below specifies how your tabular data will be transformed into $2 edits. You can drag and drop the column names below in most input boxes: for each row, edits will be generated with the values in these columns.",
|
||||
"wikibase-schema/dialog-explanation": "You are currently working against <a href=\"$1\" target=\"_blank\">$2</a>. You should have your data reconciled to reconciliation services linked to $2 first. The schema below specifies how your tabular data will be transformed into $2 edits. You can drag and drop the column names below in most input boxes: for each row, edits will be generated with the values in these columns.",
|
||||
"wikibase-schema/preview-explanation": "This tab shows the first edits (out of $1) that will be made once you upload the changes to <a href=\"$2\" target=\"_blank\">$3</a>. You can use facets to inspect the edits on particular items.",
|
||||
"wikibase-schema/schema-tab-header": "Schema",
|
||||
"wikibase-schema/warnings-tab-header": "Issues",
|
||||
@ -58,7 +58,7 @@
|
||||
"wikibase-schema/description-override": "Description (override if present)",
|
||||
"wikibase-schema/override-term": "override if present",
|
||||
"wikibase-schema/alias": "Alias",
|
||||
"wikibase-schema/item-or-reconciled-column": "type item or drag reconciled column here",
|
||||
"wikibase-schema/entity-or-reconciled-column": "type entity or drag reconciled column here",
|
||||
"wikibase-schema/amount": "amount",
|
||||
"wikibase-schema/unit": "unit",
|
||||
"wikibase-schema/full-url": "full URL including the protocol",
|
||||
@ -77,6 +77,7 @@
|
||||
"wikibase-schema/discard-schema-changes-alt": "Discard the changes made to the schema.",
|
||||
"wikibase-schema/incomplete-schema-could-not-be-saved": "Your schema is incomplete so it cannot be saved yet.",
|
||||
"wikibase-schema/unsaved-warning": "You have made unsaved changes to your Wikibase schema. Close anyway?",
|
||||
"wikibase-schema/incompatible-site-iri-reconciled-column": "This column is reconciled to the identifier space $1, but this input requires a column reconciled to $2.",
|
||||
"wikibase-preview/new-id": "new item",
|
||||
"wikibase-account/dialog-header": "$1 account",
|
||||
"wikibase-account/explain-log-in": "Logging in to <a href=\"$1\" target=\"_blank\">$2</a> lets you to upload edits directly from OpenRefine.",
|
||||
@ -192,7 +193,7 @@
|
||||
"warnings-messages/non-printable-characters/title": "Non-printable characters in strings.",
|
||||
"warnings-messages/non-printable-characters/body": "Strings such as <span class=\"wb-issue-preformat\">{example_string}</span> contain non-printable characters.",
|
||||
"warnings-messages/invalid-identifier-space/title": "Invalid identifier space for reconciled cells.",
|
||||
"warnings-messages/invalid-identifier-space/body": "Some reconciled cells such as <span class=\"wb-issue-preformat\">{example_cell}</span> were ignored because they are not reconciled to {wikibase_name}.",
|
||||
"warnings-messages/invalid-identifier-space/body": "Some reconciled cells such as <span class=\"wb-issue-preformat\">{example_cell}</span> were ignored because they are not reconciled to <span class=\"wb-issue-preformat\">{expected_site_iri}</span>.",
|
||||
"warnings-messages/ignored-language/title": "Invalid language identifiers.",
|
||||
"warnings-messages/ignored-language/body": "Some language identifiers are invalid, such as <span class=\"wb-issue-preformat\">{example_value}</span>. See the <a href=\"https://www.wikidata.org/wiki/Wikidata:Tools/OpenRefine/Editing/Schema_alignment#Languages\" target=\"_blank\">allowed values</a>.",
|
||||
"warnings-messages/ignored-date/title": "Invalid date formats.",
|
||||
|
@ -6,7 +6,7 @@
|
||||
"wikibase-extension/export-to-qs": "Exporter vers QuickStatements",
|
||||
"wikibase-extension/quickstatements-export-name": "QuickStatements",
|
||||
"wikibase-schema/dialog-header": "Aligner sur la Wikibase",
|
||||
"wikibase-schema/dialog-explanation": "Vous travaillez actuellement contre <a href=\"$1\" target=\"_blank\">$2</a>. D'abord, vous devriez réconcilier vos données avec les services de réconciliation associés à $2 (tels que <a href=\"$3\" target=\"_blank\">$3</a>). Le schéma ci-dessous spécifie comment vos données tabulaires seront transformées en $2 modifications. Vous pouvez glisser-déposer les noms des colonnes ci-dessous dans la plupart des champs de saisie : pour chaque ligne, des modifications seront générées avec les valeurs dans ces colonnes.",
|
||||
"wikibase-schema/dialog-explanation": "Vous travaillez actuellement contre <a href=\"$1\" target=\"_blank\">$2</a>. D'abord, vous devriez réconcilier vos données avec les services de réconciliation associés à $2. Le schéma ci-dessous spécifie comment vos données tabulaires seront transformées en $2 modifications. Vous pouvez glisser-déposer les noms des colonnes ci-dessous dans la plupart des champs de saisie : pour chaque ligne, des modifications seront générées avec les valeurs dans ces colonnes.",
|
||||
"wikibase-schema/preview-explanation": "Cet onglet affiche les premières modifications (sur $1) qui seront effectuées une fois que vous aurez importé les modifications dans <a href=\"$2\" target=\"_blank\">$3</a>. Vous pouvez utiliser des facettes pour inspecter les modifications sur des éléments particuliers.",
|
||||
"wikibase-schema/schema-tab-header": "Schéma",
|
||||
"wikibase-schema/warnings-tab-header": "Problèmes",
|
||||
|
@ -85,5 +85,11 @@
|
||||
"warnings-messages/property-found-in-qualifier/body": "U heeft {property_entity} als kwalificatie gebruikt, maar deze is daar niet voor ontworpen.",
|
||||
"warnings-messages/property-found-in-reference/title": "{property_entity} gebruikt als bron.",
|
||||
"warnings-messages/property-found-in-reference/body": "U heeft {property_entity} gebruikt als bron, maar deze is daar niet voor ontworpen.",
|
||||
"warnings-messages/missing-mandatory-qualifiers/title": "{statement_property_entity} mist een {missing_property_entity}-kwalificatie."
|
||||
"warnings-messages/missing-mandatory-qualifiers/title": "{statement_property_entity} mist een {missing_property_entity}-kwalificatie.",
|
||||
"wikibase-extension/qs-file": "QuickStatements-bestand",
|
||||
"wikibase-extension/wikibase-schema": "Wikibase schema",
|
||||
"wikibase-extension/select-wikibase-instance": "Selecteer Wikibase instance",
|
||||
"wikibase-extension/wikibase-edits": "Wikibase bewerkingen…",
|
||||
"wikibase-extension/export-wikibase-schema": "Wikibase schema exporteren",
|
||||
"wikibase-management/dialog-header": "Selecteer Wikibase instance"
|
||||
}
|
||||
|
@ -86,9 +86,14 @@ WikibaseDialog.addWikibaseManifest = function () {
|
||||
}
|
||||
|
||||
WikibaseManager.addWikibase(manifest);
|
||||
|
||||
// pre-register reconciliation services mentioned by this manifest
|
||||
for (let reconEndpoint of WikibaseManager.getReconciliationEndpoints(manifest)) {
|
||||
let lang = $.i18n('core-recon/wd-recon-lang');
|
||||
let reconEndpoint = manifest.reconciliation.endpoint.replace("${lang}", lang);
|
||||
ReconciliationManager.getOrRegisterServiceFromUrl(reconEndpoint, function () {}, true);
|
||||
let endpoint = reconEndpoint.replace("${lang}", lang);
|
||||
ReconciliationManager.getOrRegisterServiceFromUrl(endpoint, function () {}, true);
|
||||
}
|
||||
|
||||
DialogSystem.dismissUntil(level - 1);
|
||||
WikibaseDialog.populateDialog();
|
||||
};
|
||||
@ -113,8 +118,10 @@ WikibaseDialog.validateManifest = function (manifest) {
|
||||
if (!WikibaseDialog.ajv) {
|
||||
WikibaseDialog.ajv = new Ajv();
|
||||
WikibaseDialog.validateWikibaseManifestV1 = WikibaseDialog.ajv.compile(WikibaseManifestSchemaV1);
|
||||
WikibaseDialog.validateWikibaseManifestV2 = WikibaseDialog.ajv.compile(WikibaseManifestSchemaV2);
|
||||
}
|
||||
|
||||
if (manifest.version !== undefined && manifest.version.startsWith('1.')) {
|
||||
if (WikibaseDialog.validateWikibaseManifestV1(manifest)) {
|
||||
return true;
|
||||
} else {
|
||||
@ -124,4 +131,15 @@ WikibaseDialog.validateManifest = function (manifest) {
|
||||
alert(errMsg);
|
||||
return false;
|
||||
}
|
||||
} else {
|
||||
if (WikibaseDialog.validateWikibaseManifestV2(manifest)) {
|
||||
return true;
|
||||
} else {
|
||||
let errMsg = WikibaseDialog.ajv.errorsText(WikibaseDialog.validateWikibaseManifestV2.errors, {
|
||||
dataVar: "manifest"
|
||||
});
|
||||
alert(errMsg);
|
||||
return false;
|
||||
}
|
||||
}
|
||||
};
|
||||
|
@ -121,8 +121,7 @@ SchemaAlignment._rerenderTabs = function() {
|
||||
var schemaElmts = this._schemaElmts = DOM.bind(schemaTab);
|
||||
schemaElmts.dialogExplanation.html($.i18n('wikibase-schema/dialog-explanation',
|
||||
WikibaseManager.getSelectedWikibaseMainPage(),
|
||||
WikibaseManager.getSelectedWikibaseName(),
|
||||
WikibaseManager.getSelectedWikibaseReconEndpoint().replace("${lang}", "en")));
|
||||
WikibaseManager.getSelectedWikibaseName()));
|
||||
this._plusButton($.i18n('wikibase-schema/add-item-button'), schemaElmts.addItemButton);
|
||||
schemaElmts.addItemButton.click(function(e) {
|
||||
SchemaAlignment._addItem();
|
||||
@ -162,17 +161,24 @@ SchemaAlignment._rerenderTabs = function() {
|
||||
previewElmts.invalidSchemaWarningPreview.text($.i18n('wikibase-schema/invalid-schema-warning-preview'));
|
||||
this._previewPanes = $(".schema-alignment-dialog-preview");
|
||||
|
||||
var reconServiceURL = WikibaseManager.getSelectedWikibaseReconEndpoint()
|
||||
.replace("${lang}", $.i18n("core-recon/wd-recon-lang"));
|
||||
// add all recon services for all the entity types of the Wikibase instance
|
||||
var entityTypes = WikibaseManager.getSelectedWikibaseAvailableEntityTypes();
|
||||
SchemaAlignment._reconService = {};
|
||||
for (let entityType of entityTypes) {
|
||||
var reconServiceTemplate = WikibaseManager.getSelectedWikibaseReconEndpoint(entityType);
|
||||
if (reconServiceTemplate != null) {
|
||||
var reconServiceURL = reconServiceTemplate.replace("${lang}", $.i18n("core-recon/wd-recon-lang"));
|
||||
ReconciliationManager.getOrRegisterServiceFromUrl(reconServiceURL, function (service) {
|
||||
SchemaAlignment._reconService = service;
|
||||
SchemaAlignment._reconService[entityType] = service;
|
||||
}, false);
|
||||
}
|
||||
}
|
||||
|
||||
// Load the existing schema
|
||||
SchemaAlignment._reset(theProject.overlayModels.wikibaseSchema);
|
||||
|
||||
// Perform initial preview
|
||||
SchemaAlignment.preview();
|
||||
}, false);
|
||||
};
|
||||
|
||||
SchemaAlignment.onWikibaseChange = function() {
|
||||
@ -190,9 +196,11 @@ SchemaAlignment.updateColumns = function() {
|
||||
for (var i = 0; i < columns.length; i++) {
|
||||
var column = columns[i];
|
||||
var reconConfig = column.reconConfig;
|
||||
// make sure the column was reconciled to the target Wikibase
|
||||
// make sure the column was reconciled.
|
||||
// TODO we could potentially ignore any reconciliation to a siteIRI not
|
||||
// mentioned in the manifest…
|
||||
var cell = SchemaAlignment._createDraggableColumn(column.name,
|
||||
reconConfig && reconConfig.identifierSpace === WikibaseManager.getSelectedWikibaseSiteIri() && column.reconStats);
|
||||
reconConfig && column.reconStats ? reconConfig.identifierSpace : null);
|
||||
this._columnArea.append(cell);
|
||||
}
|
||||
|
||||
@ -327,9 +335,13 @@ SchemaAlignment._changesCleared = function() {
|
||||
.addClass('disabled');
|
||||
};
|
||||
|
||||
SchemaAlignment._createDraggableColumn = function(name, reconciled) {
|
||||
SchemaAlignment._createDraggableColumn = function(name, reconciledSiteIRI) {
|
||||
var cell = $("<div></div>").addClass('wbs-draggable-column').text(name);
|
||||
if (reconciled) {
|
||||
cell.data({
|
||||
'columnName': name,
|
||||
'reconciledSiteIRI': reconciledSiteIRI
|
||||
});
|
||||
if (reconciledSiteIRI !== null) {
|
||||
cell.addClass('wbs-reconciled-column');
|
||||
} else {
|
||||
cell.addClass('wbs-unreconciled-column');
|
||||
@ -380,7 +392,11 @@ SchemaAlignment._addItem = function(json) {
|
||||
e.preventDefault();
|
||||
});
|
||||
var inputContainer = $('<div></div>').addClass('wbs-item-input').appendTo(item);
|
||||
SchemaAlignment._initField(inputContainer, "wikibase-item", subject);
|
||||
// TODO temporary solution to pick another entity type than item
|
||||
// depending on the Wikibase manifest. To be removed in favour of proper support
|
||||
// for multiple entity types per Wikibase
|
||||
let defaultEntityType = WikibaseManager.getSelectedWikibaseDefaultEntityType();
|
||||
SchemaAlignment._initField(inputContainer, "wikibase-"+defaultEntityType, subject);
|
||||
var right = $('<div></div>').addClass('wbs-item-contents').appendTo(item);
|
||||
|
||||
// Terms
|
||||
@ -908,14 +924,15 @@ SchemaAlignment._initPropertyField = function(inputContainer, targetContainer, i
|
||||
var input = $('<input></input>').appendTo(inputContainer);
|
||||
input.attr("placeholder", $.i18n('wikibase-schema/property-placeholder'));
|
||||
|
||||
if (this._reconService !== null) {
|
||||
var endpoint = this._reconService.suggest.property;
|
||||
var suggestConfig = $.extend({}, endpoint);
|
||||
suggestConfig.key = null;
|
||||
suggestConfig.query_param_name = "prefix";
|
||||
var endpoint = WikibaseManager.getSelectedWikibaseApiForEntityType('property');
|
||||
var suggestConfig = {
|
||||
mediawiki_endpoint: endpoint,
|
||||
entity_type: 'property',
|
||||
language: $.i18n("core-recon/wd-recon-lang"),
|
||||
view_url: WikibaseManager.getSelectedWikibaseSiteIriForEntityType('property')+'{{id}}'
|
||||
};
|
||||
|
||||
input.suggestP(suggestConfig).bind("fb-select", function(evt, data) {
|
||||
// Fetch the type of this property and add the appropriate target value type
|
||||
input.suggestWikibase(suggestConfig).bind("fb-select", function(evt, data) {
|
||||
SchemaAlignment._getPropertyType(data.id, function(datatype) {
|
||||
inputContainer.data("jsonValue", {
|
||||
type : "wbpropconstant",
|
||||
@ -940,7 +957,6 @@ SchemaAlignment._initPropertyField = function(inputContainer, targetContainer, i
|
||||
});
|
||||
// adds tweaks to display the validation status more clearly, like in Wikidata
|
||||
fixSuggestInput(input);
|
||||
}
|
||||
|
||||
// Init with the provided initial value.
|
||||
if (initialValue) {
|
||||
@ -960,52 +976,34 @@ SchemaAlignment._initField = function(inputContainer, mode, initialValue, change
|
||||
changedCallback = SchemaAlignment._hasChanged;
|
||||
}
|
||||
|
||||
if (this._reconService !== null && (mode === "wikibase-item" || mode === "unit")) {
|
||||
if (mode === "wikibase-item") {
|
||||
input.attr("placeholder", $.i18n('wikibase-schema/item-or-reconciled-column'));
|
||||
// the mode for Wikibase entities has the form "wikibase-{entitytype}", such as "wikibase-item" or "wikibase-property"
|
||||
if (this._reconService !== null && (mode.startsWith("wikibase-") || mode === "unit")) {
|
||||
var entityType = null;
|
||||
if (mode.startsWith("wikibase-")) {
|
||||
input.attr("placeholder", $.i18n('wikibase-schema/entity-or-reconciled-column'));
|
||||
entityType = mode.slice("wikibase-".length);
|
||||
} else {
|
||||
input.attr("placeholder", $.i18n('wikibase-schema/unit'));
|
||||
entityType = "item";
|
||||
}
|
||||
var endpoint = null;
|
||||
endpoint = this._reconService.suggest.entity;
|
||||
var suggestConfig = $.extend({}, endpoint);
|
||||
suggestConfig.key = null;
|
||||
suggestConfig.query_param_name = "prefix";
|
||||
if ('view' in this._reconService && 'url' in this._reconService.view && !('view_url' in endpoint)) {
|
||||
suggestConfig.view_url = this._reconService.view.url;
|
||||
}
|
||||
var endpoint = WikibaseManager.getSelectedWikibaseApiForEntityType(entityType);
|
||||
var suggestConfig = {
|
||||
mediawiki_endpoint: endpoint,
|
||||
entity_type: entityType,
|
||||
language: $.i18n("core-recon/wd-recon-lang"),
|
||||
view_url: WikibaseManager.getSelectedWikibaseSiteIriForEntityType(entityType)+'{{id}'
|
||||
};
|
||||
|
||||
|
||||
input.suggest(suggestConfig).bind("fb-select", function(evt, data) {
|
||||
input.suggestWikibase(suggestConfig).bind("fb-select", function(evt, data) {
|
||||
inputContainer.data("jsonValue", {
|
||||
type : "wbitemconstant",
|
||||
qid : data.id,
|
||||
type : "wbentityidvalueconstant",
|
||||
id : data.id,
|
||||
label: data.name,
|
||||
});
|
||||
changedCallback();
|
||||
});
|
||||
// adds tweaks to display the validation status more clearly, like in Wikidata
|
||||
fixSuggestInput(input);
|
||||
|
||||
} else if (this._reconService !== null && mode === "wikibase-property") {
|
||||
var endpoint = null;
|
||||
endpoint = this._reconService.suggest.property;
|
||||
var suggestConfig = $.extend({}, endpoint);
|
||||
suggestConfig.key = null;
|
||||
suggestConfig.query_param_name = "prefix";
|
||||
|
||||
input.suggestP(suggestConfig).bind("fb-select", function(evt, data) {
|
||||
inputContainer.data("jsonValue", {
|
||||
type : "wbpropconstant",
|
||||
pid : data.id,
|
||||
label: data.name,
|
||||
datatype: "not-important",
|
||||
});
|
||||
changedCallback();
|
||||
});
|
||||
// adds tweaks to display the validation status more clearly, like in Wikidata
|
||||
fixSuggestInput(input);
|
||||
|
||||
} else if (mode === "time") {
|
||||
input.attr("placeholder", "YYYY(-MM(-DD))");
|
||||
var propagateValue = function(val) {
|
||||
@ -1176,9 +1174,15 @@ SchemaAlignment._initField = function(inputContainer, mode, initialValue, change
|
||||
// Make it droppable
|
||||
var acceptClass = ".wbs-draggable-column";
|
||||
var wbVariableType = "wbstringvariable";
|
||||
if (mode === "wikibase-item" || mode === "unit") {
|
||||
var entityType = null;
|
||||
if (mode.startsWith("wikibase-") || mode === "unit") {
|
||||
acceptClass = ".wbs-reconciled-column";
|
||||
wbVariableType = "wbitemvariable";
|
||||
wbVariableType = "wbentityvariable";
|
||||
if (mode === "unit") {
|
||||
entityType = "item";
|
||||
} else {
|
||||
entityType = mode.slice("wikibase-".length);
|
||||
}
|
||||
} else if (mode === "time") {
|
||||
wbVariableType = "wbdatevariable";
|
||||
} else if (mode === "globe-coordinate") {
|
||||
@ -1194,6 +1198,16 @@ SchemaAlignment._initField = function(inputContainer, mode, initialValue, change
|
||||
accept: acceptClass,
|
||||
}).on("drop", function (evt, ui) {
|
||||
var column = ui.draggable.clone();
|
||||
if (entityType !== null) {
|
||||
// check that the siteIRI of the reconciled column matches
|
||||
// the expected one.
|
||||
var expectedSiteIRI = WikibaseManager.getSelectedWikibaseSiteIriForEntityType(entityType);
|
||||
var actualSiteIRI = ui.draggable.data('reconciledSiteIRI');
|
||||
if (actualSiteIRI !== expectedSiteIRI) {
|
||||
alert($.i18n('wikibase-schema/incompatible-site-iri-reconciled-column', actualSiteIRI, expectedSiteIRI));
|
||||
return false;
|
||||
}
|
||||
}
|
||||
acceptDraggableColumn(column);
|
||||
inputContainer.data("jsonValue", {
|
||||
type : wbVariableType,
|
||||
@ -1210,10 +1224,12 @@ SchemaAlignment._initField = function(inputContainer, mode, initialValue, change
|
||||
|
||||
// Init with the provided initial value.
|
||||
if (initialValue) {
|
||||
if (initialValue.type === "wbitemconstant" || initialValue.type === "wbpropconstant") {
|
||||
if (initialValue.type === "wbentityidvalueconstant" ||
|
||||
/* item for backwards-compatibility purposes */
|
||||
initialValue.type === "wbitemconstant" || initialValue.type === "wbpropconstant") {
|
||||
input.val(initialValue.label);
|
||||
input.addClass("wbs-validated-input");
|
||||
} else if (initialValue.type == "wbitemvariable") {
|
||||
} else if (initialValue.type == "wbentityvariable") {
|
||||
var cell = SchemaAlignment._createDraggableColumn(initialValue.columnName, true);
|
||||
acceptDraggableColumn(cell);
|
||||
} else if (initialValue.type === "wbstringconstant" ||
|
||||
@ -1279,6 +1295,7 @@ SchemaAlignment.getJSON = function() {
|
||||
return {
|
||||
itemDocuments: list,
|
||||
siteIri: WikibaseManager.getSelectedWikibaseSiteIri(),
|
||||
entityTypeSiteIri: Object.fromEntries(WikibaseManager.getSelectedWikibaseAvailableEntityTypes().map(et => [et, WikibaseManager.getSelectedWikibaseSiteIriForEntityType(et)])),
|
||||
mediaWikiApiEndpoint: WikibaseManager.getSelectedWikibaseApi()
|
||||
};
|
||||
} else {
|
||||
|
@ -24,6 +24,18 @@ WikibaseManager.getSelectedWikibaseApi = function () {
|
||||
return WikibaseManager.getSelectedWikibase().mediawiki.api;
|
||||
};
|
||||
|
||||
WikibaseManager.getSelectedWikibaseApiForEntityType = function (entityType) {
|
||||
let manifest = WikibaseManager.getSelectedWikibase();
|
||||
// version 1
|
||||
if (manifest.version.split('.')[0] === '1') {
|
||||
return manifest.wikibase.site_iri;
|
||||
} else { // version 2 or above
|
||||
let record = manifest.entity_types[entityType];
|
||||
let api = record === undefined ? undefined : record.mediawiki_api;
|
||||
return api === undefined ? manifest.mediawiki.api : api;
|
||||
}
|
||||
};
|
||||
|
||||
WikibaseManager.getSelectedWikibaseName = function () {
|
||||
return WikibaseManager.selected;
|
||||
};
|
||||
@ -47,13 +59,81 @@ WikibaseManager.getSelectedWikibaseEditGroupsURLSchema = function() {
|
||||
|
||||
/**
|
||||
* Returns the default reconciliation service URL of the Wikibase,
|
||||
* such as "https://wikidata.reconci.link/${lang}/api".
|
||||
* for a given entity type, such as "https://wikidata.reconci.link/${lang}/api".
|
||||
*
|
||||
* Notice that there is a "${lang}" variable in the URL, which should
|
||||
* be replaced with the actual language code.
|
||||
*/
|
||||
WikibaseManager.getSelectedWikibaseReconEndpoint = function () {
|
||||
return WikibaseManager.getSelectedWikibase().reconciliation.endpoint;
|
||||
WikibaseManager.getSelectedWikibaseReconEndpoint = function (entityType) {
|
||||
let manifest = WikibaseManager.getSelectedWikibase();
|
||||
// version 1
|
||||
if (manifest.version.split('.')[0] === '1') {
|
||||
if (entityType === 'item') {
|
||||
return manifest.reconciliation.endpoint;
|
||||
}
|
||||
return null;
|
||||
} else { // version 2 or above
|
||||
let record = manifest.entity_types[entityType];
|
||||
return record === undefined ? undefined : record.reconciliation_endpoint;
|
||||
}
|
||||
};
|
||||
|
||||
WikibaseManager.getReconciliationEndpoints = function (manifest) {
|
||||
// version 1
|
||||
if (manifest.version.split('.')[0] === '1') {
|
||||
return [manifest.reconciliation.endpoint];
|
||||
} else { // version 2 or above
|
||||
return Object.keys(manifest.entity_types)
|
||||
.map(k => manifest.entity_types[k].reconciliation_endpoint)
|
||||
.filter(endpoint => endpoint != null);
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
WikibaseManager.getSelectedWikibaseSiteIriForEntityType = function (entityType) {
|
||||
let manifest = WikibaseManager.getSelectedWikibase();
|
||||
// version 1
|
||||
if (manifest.version.split('.')[0] === '1') {
|
||||
return manifest.wikibase.site_iri;
|
||||
} else { // version 2 or above
|
||||
let record = manifest.entity_types[entityType];
|
||||
return record === undefined ? undefined : record.site_iri;
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
WikibaseManager.getSelectedWikibaseAvailableEntityTypes = function () {
|
||||
let manifest = WikibaseManager.getSelectedWikibase();
|
||||
// version 1
|
||||
if (manifest.version.split('.')[0] === '1') {
|
||||
return ['item', 'property'];
|
||||
} else { // version 2 or above
|
||||
return Object.keys(manifest.entity_types);
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
/**
|
||||
* TODO temporary function to be removed once we have proper support
|
||||
* for multiple entity types. This one just guesses which item-like
|
||||
* entity type we should let the user edit, based on the manifest.
|
||||
* - for Wikidata it returns 'item'
|
||||
* - for Commons it returns 'mediainfo'
|
||||
*/
|
||||
WikibaseManager.getSelectedWikibaseDefaultEntityType = function () {
|
||||
let manifest = WikibaseManager.getSelectedWikibase();
|
||||
// version 1
|
||||
if (manifest.version.split('.')[0] === '1') {
|
||||
return 'item';
|
||||
} else { // version 2 or above
|
||||
for (let entityType of ['item', 'property', 'mediainfo']) {
|
||||
if (manifest.entity_types[entityType] !== undefined &&
|
||||
manifest.entity_types[entityType].site_iri === manifest.wikibase.site_iri) {
|
||||
return entityType;
|
||||
}
|
||||
}
|
||||
return 'item'; // by default, as a fallback
|
||||
}
|
||||
};
|
||||
|
||||
WikibaseManager.selectWikibase = function (wikibaseName) {
|
||||
|
@ -1,6 +1,6 @@
|
||||
const WikibaseManifestSchemaV1 = {
|
||||
"$schema": "http://json-schema.org/draft-07/schema#",
|
||||
"$id": "TBD",
|
||||
"$id": "https://openrefine.org/schemas/wikibase-manifest-v1.json",
|
||||
"type": "object",
|
||||
"description": "The schema validates Wikibase manifests with version 1.x. The manifest contains configurations of basic information (e.g. URL of the main page), extensions (e.g. OAuth extension) or external services (e.g. Reconciliation service) of a Wikibase",
|
||||
"properties": {
|
||||
|
@ -0,0 +1,142 @@
|
||||
const WikibaseManifestSchemaV2 = {
|
||||
"$schema": "http://json-schema.org/draft-07/schema#",
|
||||
"$id": "https://openrefine.org/schemas/wikibase-manifest-v2.json",
|
||||
"type": "object",
|
||||
"description": "The schema validates Wikibase manifests with version 2.x. The manifest contains configurations of basic information (e.g. URL of the main page), extensions (e.g. OAuth extension) or external services (e.g. Reconciliation service) of a Wikibase",
|
||||
"properties": {
|
||||
"version": {
|
||||
"type": "string",
|
||||
"pattern": "^2\\.[0-9]+$",
|
||||
"description": "The version of the Wikibase manifest, in the format of 2.x"
|
||||
},
|
||||
"mediawiki": {
|
||||
"type": "object",
|
||||
"description": "The configurations of the MediaWiki engine",
|
||||
"properties": {
|
||||
"name": {
|
||||
"type": "string",
|
||||
"description": "The name of the Wikibase, such as 'Wikidata'"
|
||||
},
|
||||
"root": {
|
||||
"type": "string",
|
||||
"format": "url",
|
||||
"pattern": "^.*/$",
|
||||
"description": "The URL of the root of the Wikibase, such as 'https://www.wikidata.org/wiki/'. The trailing slash cannot be omitted"
|
||||
},
|
||||
"main_page": {
|
||||
"type": "string",
|
||||
"format": "url",
|
||||
"description": "The URL of the main page of the Wikibase, such as 'https://www.wikidata.org/wiki/Wikidata:Main_Page'"
|
||||
},
|
||||
"api": {
|
||||
"type": "string",
|
||||
"format": "url",
|
||||
"description": "The MediaWiki API endpoint of the Wikibase, such as 'https://www.wikidata.org/w/api.php'"
|
||||
}
|
||||
},
|
||||
"required": ["name", "root", "main_page", "api"]
|
||||
},
|
||||
"wikibase": {
|
||||
"type": "object",
|
||||
"description": "The configurations of the Wikibase extension",
|
||||
"properties": {
|
||||
"site_iri": {
|
||||
"type": "string",
|
||||
"format": "url",
|
||||
"pattern": "^.*/$",
|
||||
"description": "The IRI of the Wikibase, such as 'http://www.wikidata.org/entity/'. This should match the IRI prefixes used in RDF serialization. Be careful about using 'http' or 'https', because any variation will break comparisons at various places. The trailing slash cannot be omitted"
|
||||
},
|
||||
"maxlag": {
|
||||
"type": "integer",
|
||||
"description": "The default maxlag of this Wikibase. For Wikidata, the default value is 5 (seconds)"
|
||||
},
|
||||
"properties": {
|
||||
"type": "object",
|
||||
"properties": {
|
||||
"instance_of": {
|
||||
"type": "string",
|
||||
"description": "The 'instance of' qid of the Wikibase ('P31' for Wikidata)"
|
||||
},
|
||||
"subclass_of": {
|
||||
"type": "string",
|
||||
"description": "The 'subclass of' qid of the Wikibase ('P279' for Wikidata)"
|
||||
}
|
||||
},
|
||||
"required": ["instance_of", "subclass_of"]
|
||||
},
|
||||
"constraints": {
|
||||
"type": "object",
|
||||
"description": "Constraints related qids and pids, not required since the constraints extension may not be installed",
|
||||
"properties": {
|
||||
"property_constraint_pid": {
|
||||
"type": "string",
|
||||
"description": "The property constraint pid of the Wikibase ('P2302' for Wikidata)"
|
||||
}
|
||||
},
|
||||
"patternProperties": {
|
||||
"^.*$": {
|
||||
"type": "string",
|
||||
"description": "If a pid/qid is missing, constraint checks depending on it will be skipped"
|
||||
}
|
||||
},
|
||||
"required": ["property_constraint_pid"]
|
||||
}
|
||||
},
|
||||
"required": ["site_iri", "maxlag", "properties"]
|
||||
},
|
||||
"oauth": {
|
||||
"type": "object",
|
||||
"description": "The configurations of the OAuth extension. Not required. Configuring this if and only if the OAuth extension is installed",
|
||||
"properties": {
|
||||
"registration_page": {
|
||||
"type": "string",
|
||||
"format": "url",
|
||||
"description": "The url of the OAuth consumer registration page, 'https://meta.wikimedia.org/wiki/Special:OAuthConsumerRegistration/propose' for Wikidata"
|
||||
}
|
||||
},
|
||||
"required": ["registration_page"]
|
||||
},
|
||||
"entity_types": {
|
||||
"type": "object",
|
||||
"description": "The available entity types on this Wikibase, with particular settings for each of them. The keys of this object are strings such as 'item', 'property', 'mediainfo' or 'lexeme'",
|
||||
"patternProperties": {
|
||||
"^.*$": {
|
||||
"type": "object",
|
||||
"description": "The settings for the given entity type.",
|
||||
"properties": {
|
||||
"reconciliation_endpoint": {
|
||||
"type": "string",
|
||||
"format": "url",
|
||||
"pattern": "^.*\\${lang}.*$",
|
||||
"description": "The default reconciliation API endpoint of the Wikibase for this entity type, the endpoint should include the language variable '${lang}', such as 'https://wikidata.reconci.link/${lang}/api'"
|
||||
},
|
||||
"site_iri": {
|
||||
"type": "string",
|
||||
"format": "url",
|
||||
"description": "The RDF prefix in which URIs for entities of this type are minted. If entities of this type are edited locally, this should be the global site_iri of the Wikibase. If those entities are drawn from another Wikibase instance, it should be the site_iri of that instance."
|
||||
},
|
||||
"mediawiki_api": {
|
||||
"type": "string",
|
||||
"format": "url",
|
||||
"description": "The MediaWiki API endpoint of the Wikibase, such as 'https://www.wikidata.org/w/api.php'"
|
||||
}
|
||||
},
|
||||
"required": ["site_iri"]
|
||||
}
|
||||
}
|
||||
},
|
||||
"editgroups": {
|
||||
"type": "object",
|
||||
"description": "The configurations of the EditGroups service of the Wikibase",
|
||||
"properties": {
|
||||
"url_schema": {
|
||||
"type": "string",
|
||||
"pattern": "^.*\\${batch_id}.*$",
|
||||
"description": "The URL schema used in edits summary. This is used for EditGroups to extract the batch id from a batch of edits and for linking to the EditGroups page of the batch. The URL schema must contains the variable '${batch_id}', such as '([[:toollabs:editgroups/b/OR/${batch_id}|details]])' for Wikidata"
|
||||
},
|
||||
},
|
||||
"required": ["url_schema"]
|
||||
}
|
||||
},
|
||||
"required": ["version", "mediawiki", "wikibase", "entity_types"]
|
||||
};
|
@ -0,0 +1,142 @@
|
||||
|
||||
/**
|
||||
* Adaptation of the suggest widget to query the Wikibase autocomplete API directly
|
||||
*/
|
||||
|
||||
(function() {
|
||||
|
||||
/**
|
||||
* Options:
|
||||
* mediawiki_endpoint: url of the MediaWiki API
|
||||
* entity_type: type of entity to suggest (one of form, item, lexeme, property, sense, mediainfo…)
|
||||
* language: language code of the language to search in
|
||||
*/
|
||||
|
||||
$.suggest(
|
||||
"suggestWikibase",
|
||||
$.extend(
|
||||
true,
|
||||
{},
|
||||
$.suggest.suggest.prototype,
|
||||
{
|
||||
create_item: function(data, response_data) {
|
||||
var css = this.options.css;
|
||||
|
||||
var li = $("<li>").addClass(css.item);
|
||||
|
||||
var name = $("<div>")
|
||||
.addClass(css.item_name)
|
||||
.append(
|
||||
$("<label>")
|
||||
.append($.suggest.strongify(data.name || data.guid, response_data.prefix)));
|
||||
|
||||
data.name = name.text(); // this converts html escaped strings like "&" back to "&"
|
||||
if (data.description) {
|
||||
var descriptionSpan = $("<span></span>").text(data.description);
|
||||
name.append(descriptionSpan);
|
||||
}
|
||||
|
||||
li.append(name);
|
||||
|
||||
name.prepend($("<div>").addClass(css.item_type).text(data.id));
|
||||
|
||||
return li;
|
||||
},
|
||||
|
||||
request: function(val, cursor) {
|
||||
var self = this,
|
||||
o = this.options;
|
||||
|
||||
var query = val;
|
||||
|
||||
var entity_type = o.entity_type || 'item';
|
||||
|
||||
var data = {
|
||||
action: 'wbsearchentities',
|
||||
language: o.language,
|
||||
search: query,
|
||||
type: entity_type,
|
||||
format: 'json',
|
||||
origin: '*'
|
||||
};
|
||||
|
||||
if (cursor) {
|
||||
data['continue'] = cursor;
|
||||
}
|
||||
|
||||
var url = o.mediawiki_endpoint + "?" + $.param(data, true);
|
||||
var cached = $.suggest.cache[url];
|
||||
if (cached) {
|
||||
this.response(cached, cursor ? cursor : -1, true);
|
||||
return;
|
||||
}
|
||||
|
||||
clearTimeout(this.request.timeout);
|
||||
|
||||
var ajax_options = {
|
||||
url: o.mediawiki_endpoint,
|
||||
data: data,
|
||||
traditional: true,
|
||||
beforeSend: function(xhr) {
|
||||
var calls = self.input.data("request.count.suggest") || 0;
|
||||
if (!calls) {
|
||||
self.trackEvent(self.name, "start_session");
|
||||
}
|
||||
calls += 1;
|
||||
self.trackEvent(self.name, "request", "count", calls);
|
||||
self.input.data("request.count.suggest", calls);
|
||||
},
|
||||
success: function(data) {
|
||||
$.suggest.cache[url] = data;
|
||||
// translate the results of the MediaWiki API to that of the reconciliation API
|
||||
var translated = {
|
||||
prefix: val, // keep track of prefix to match up response with input value
|
||||
result: (data.search || []).map(result => { return {
|
||||
id: result.id,
|
||||
name: result.label,
|
||||
description: result.description};})
|
||||
};
|
||||
self.response(translated, cursor ? cursor : -1);
|
||||
},
|
||||
error: function(xhr) {
|
||||
self.status_error();
|
||||
self.trackEvent(self.name, "request", "error", {
|
||||
url: this.url,
|
||||
response: xhr ? xhr.responseText : ''
|
||||
});
|
||||
self.input.trigger("fb-error", Array.prototype.slice.call(arguments));
|
||||
},
|
||||
complete: function(xhr) {
|
||||
if (xhr) {
|
||||
self.trackEvent(self.name, "request", "tid",
|
||||
xhr.getResponseHeader("X-Metaweb-TID"));
|
||||
}
|
||||
},
|
||||
dataType: "json",
|
||||
cache: true
|
||||
};
|
||||
|
||||
this.request.timeout = setTimeout(function() {
|
||||
$.ajax(ajax_options);
|
||||
}, o.xhr_delay);
|
||||
}
|
||||
|
||||
}));
|
||||
|
||||
$.extend(
|
||||
$.suggest.suggestWikibase,
|
||||
{
|
||||
defaults: $.extend(
|
||||
true,
|
||||
{},
|
||||
$.suggest.suggest.defaults, {
|
||||
scoring: "schema",
|
||||
css: { pane: "fbs-pane fbs-pane-type" }
|
||||
}
|
||||
)
|
||||
}
|
||||
);
|
||||
|
||||
})();
|
||||
|
||||
|
@ -15,8 +15,7 @@
|
||||
</parent>
|
||||
|
||||
<properties>
|
||||
<powermock.version>2.0.9</powermock.version>
|
||||
<wdtk.version>0.12.1</wdtk.version>
|
||||
<wdtk.version>0.12.1-SNAPSHOT</wdtk.version>
|
||||
</properties>
|
||||
|
||||
<build>
|
||||
@ -78,7 +77,7 @@
|
||||
<scope>provided</scope>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>org.wikidata.wdtk</groupId>
|
||||
<groupId>org.openrefine.dependencies.wdtk</groupId>
|
||||
<artifactId>wdtk-wikibaseapi</artifactId>
|
||||
<version>${wdtk.version}</version>
|
||||
</dependency>
|
||||
@ -88,12 +87,12 @@
|
||||
<version>${jackson.version}</version>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>org.wikidata.wdtk</groupId>
|
||||
<groupId>org.openrefine.dependencies.wdtk</groupId>
|
||||
<artifactId>wdtk-datamodel</artifactId>
|
||||
<version>${wdtk.version}</version>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>org.wikidata.wdtk</groupId>
|
||||
<groupId>org.openrefine.dependencies.wdtk</groupId>
|
||||
<artifactId>wdtk-util</artifactId>
|
||||
<version>${wdtk.version}</version>
|
||||
</dependency>
|
||||
@ -121,15 +120,9 @@
|
||||
<scope>test</scope>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>org.powermock</groupId>
|
||||
<artifactId>powermock-module-testng</artifactId>
|
||||
<version>${powermock.version}</version>
|
||||
<scope>test</scope>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>org.powermock</groupId>
|
||||
<artifactId>powermock-api-mockito2</artifactId>
|
||||
<version>${powermock.version}</version>
|
||||
<groupId>org.mockito</groupId>
|
||||
<artifactId>mockito-core</artifactId>
|
||||
<version>${mockito.version}</version>
|
||||
<scope>test</scope>
|
||||
</dependency>
|
||||
<dependency>
|
||||
|
@ -165,7 +165,7 @@ public class ConnectionManager {
|
||||
/**
|
||||
* For testability.
|
||||
*/
|
||||
static BasicApiConnection convertToBasicApiConnection(Map<String, Object> map) throws JsonProcessingException {
|
||||
BasicApiConnection convertToBasicApiConnection(Map<String, Object> map) throws JsonProcessingException {
|
||||
ObjectMapper mapper = new ObjectMapper();
|
||||
String json = mapper.writeValueAsString(map);
|
||||
return mapper.readValue(json, BasicApiConnection.class);
|
||||
|
@ -72,6 +72,8 @@ public class LoginCommand extends Command {
|
||||
|
||||
static final Pattern cookieKeyDisallowedCharacters = Pattern.compile("[^a-zA-Z0-9\\-!#$%&'*+.?\\^_`|~]");
|
||||
|
||||
protected ConnectionManager manager = null;
|
||||
|
||||
@Override
|
||||
public void doPost(HttpServletRequest request, HttpServletResponse response)
|
||||
throws ServletException, IOException {
|
||||
@ -80,7 +82,9 @@ public class LoginCommand extends Command {
|
||||
return;
|
||||
}
|
||||
|
||||
ConnectionManager manager = ConnectionManager.getInstance();
|
||||
if (manager == null) {
|
||||
manager = ConnectionManager.getInstance();
|
||||
}
|
||||
|
||||
String mediawikiApiEndpoint = removeCRLF(request.getParameter(API_ENDPOINT));
|
||||
if (isBlank(mediawikiApiEndpoint)) {
|
||||
@ -188,7 +192,6 @@ public class LoginCommand extends Command {
|
||||
return;
|
||||
}
|
||||
|
||||
ConnectionManager manager = ConnectionManager.getInstance();
|
||||
Map<String, Object> jsonResponse = new HashMap<>();
|
||||
if (manager.isLoggedIn(mediawikiApiEndpoint)) {
|
||||
jsonResponse.put("logged_in", manager.isLoggedIn(mediawikiApiEndpoint));
|
||||
@ -281,4 +284,8 @@ public class LoginCommand extends Command {
|
||||
Matcher matcher = cookieKeyDisallowedCharacters.matcher(key);
|
||||
return matcher.replaceAll("-");
|
||||
}
|
||||
|
||||
protected void setConnectionManager(ConnectionManager connectionManager) {
|
||||
this.manager = connectionManager;
|
||||
}
|
||||
}
|
||||
|
@ -73,7 +73,7 @@ public class PreviewWikibaseSchemaCommand extends Command {
|
||||
try {
|
||||
schema = WikibaseSchema.reconstruct(schemaJson);
|
||||
} catch (IOException e) {
|
||||
respondError(response, "Wikibase schema could not be parsed.");
|
||||
respondError(response, "Wikibase schema could not be parsed. Error message: "+e.getMessage());
|
||||
return;
|
||||
}
|
||||
} else {
|
||||
|
@ -71,7 +71,7 @@ public class SaveWikibaseSchemaCommand extends Command {
|
||||
// We do not use respondException here because this is an expected
|
||||
// exception which happens every time a user tries to save an incomplete
|
||||
// schema - the exception should not be logged.
|
||||
respondError(response, "Wikibase schema could not be parsed.");
|
||||
respondError(response, String.format("Wikibase schema could not be parsed: ", e.getMessage()));
|
||||
} catch (Exception e) {
|
||||
// This is an unexpected exception, so we log it.
|
||||
respondException(response, e);
|
||||
|
@ -25,11 +25,15 @@ package org.openrefine.wikidata.editing;
|
||||
|
||||
import java.io.IOException;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Collection;
|
||||
import java.util.Collections;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.Map.Entry;
|
||||
import java.util.Set;
|
||||
import java.util.stream.Collectors;
|
||||
|
||||
import org.apache.commons.lang.NotImplementedException;
|
||||
import org.openrefine.wikidata.schema.entityvalues.ReconEntityIdValue;
|
||||
import org.openrefine.wikidata.schema.exceptions.NewItemNotCreatedYetException;
|
||||
import org.openrefine.wikidata.updates.TermedStatementEntityUpdate;
|
||||
@ -37,10 +41,17 @@ import org.openrefine.wikidata.updates.scheduler.WikibaseAPIUpdateScheduler;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
import org.wikidata.wdtk.datamodel.helpers.Datamodel;
|
||||
import org.wikidata.wdtk.datamodel.interfaces.AliasUpdate;
|
||||
import org.wikidata.wdtk.datamodel.interfaces.EntityDocument;
|
||||
import org.wikidata.wdtk.datamodel.interfaces.EntityIdValue;
|
||||
import org.wikidata.wdtk.datamodel.interfaces.ItemDocument;
|
||||
import org.wikidata.wdtk.datamodel.interfaces.ItemIdValue;
|
||||
import org.wikidata.wdtk.datamodel.interfaces.MediaInfoDocument;
|
||||
import org.wikidata.wdtk.datamodel.interfaces.MediaInfoIdValue;
|
||||
import org.wikidata.wdtk.datamodel.interfaces.MediaInfoUpdate;
|
||||
import org.wikidata.wdtk.datamodel.interfaces.MonolingualTextValue;
|
||||
import org.wikidata.wdtk.datamodel.interfaces.StatementUpdate;
|
||||
import org.wikidata.wdtk.datamodel.interfaces.TermUpdate;
|
||||
import org.wikidata.wdtk.wikibaseapi.WikibaseDataEditor;
|
||||
import org.wikidata.wdtk.wikibaseapi.WikibaseDataFetcher;
|
||||
import org.wikidata.wdtk.wikibaseapi.apierrors.MediaWikiApiErrorException;
|
||||
@ -149,8 +160,8 @@ public class EditBatchProcessor {
|
||||
// New item
|
||||
if (update.isNew()) {
|
||||
ReconEntityIdValue newCell = (ReconEntityIdValue) update.getItemId();
|
||||
if (newCell instanceof ItemIdValue) {
|
||||
update = update.normalizeLabelsAndAliases();
|
||||
|
||||
ItemDocument itemDocument = Datamodel.makeItemDocument((ItemIdValue) update.getItemId(),
|
||||
update.getLabels().stream().collect(Collectors.toList()),
|
||||
update.getDescriptions().stream().collect(Collectors.toList()),
|
||||
@ -159,8 +170,14 @@ public class EditBatchProcessor {
|
||||
|
||||
ItemDocument createdDoc = editor.createItemDocument(itemDocument, summary, tags);
|
||||
library.setQid(newCell.getReconInternalId(), createdDoc.getEntityId().getId());
|
||||
} else if (newCell instanceof MediaInfoIdValue) {
|
||||
update = update.normalizeLabelsAndAliases();
|
||||
throw new NotImplementedException();
|
||||
}
|
||||
} else {
|
||||
// Existing item
|
||||
EntityIdValue newCell = (EntityIdValue) update.getItemId();
|
||||
if (newCell instanceof ItemIdValue) {
|
||||
ItemDocument currentDocument = (ItemDocument) currentDocs.get(update.getItemId().getId());
|
||||
List<MonolingualTextValue> labels = update.getLabels().stream().collect(Collectors.toList());
|
||||
labels.addAll(update.getLabelsIfNew().stream()
|
||||
@ -168,14 +185,31 @@ public class EditBatchProcessor {
|
||||
List<MonolingualTextValue> descriptions = update.getDescriptions().stream().collect(Collectors.toList());
|
||||
descriptions.addAll(update.getDescriptionsIfNew().stream()
|
||||
.filter(desc -> !currentDocument.getDescriptions().containsKey(desc.getLanguageCode())).collect(Collectors.toList()));
|
||||
editor.updateTermsStatements(currentDocument,
|
||||
labels,
|
||||
descriptions,
|
||||
update.getAliases().stream().collect(Collectors.toList()),
|
||||
new ArrayList<MonolingualTextValue>(),
|
||||
update.getAddedStatements().stream().collect(Collectors.toList()),
|
||||
update.getDeletedStatements().stream().collect(Collectors.toList()),
|
||||
summary, tags);
|
||||
Set<MonolingualTextValue> aliases = update.getAliases();
|
||||
Map<String, List<MonolingualTextValue>> aliasesMap = aliases.stream()
|
||||
.collect(Collectors.groupingBy(MonolingualTextValue::getLanguageCode));
|
||||
Map<String, AliasUpdate> aliasMap = aliasesMap.entrySet().stream()
|
||||
.collect(Collectors.toMap(Entry::getKey, e -> Datamodel.makeAliasUpdate(e.getValue(), Collections.emptyList())));
|
||||
editor.editEntityDocument(Datamodel.makeItemUpdate((ItemIdValue) update.getItemId(),
|
||||
currentDocument.getRevisionId(),
|
||||
Datamodel.makeTermUpdate(labels, Collections.emptyList()),
|
||||
Datamodel.makeTermUpdate(descriptions, Collections.emptyList()),
|
||||
aliasMap,
|
||||
Datamodel.makeStatementUpdate(update.getAddedStatements(), update.getDeletedStatements(), Collections.emptyList()),
|
||||
Collections.emptyList(), Collections.emptyList()),
|
||||
false, summary, tags);
|
||||
} else if (newCell instanceof MediaInfoIdValue) {
|
||||
MediaInfoDocument currentDocument = (MediaInfoDocument) currentDocs.get(update.getItemId().getId());
|
||||
List<MonolingualTextValue> labels = update.getLabels().stream().collect(Collectors.toList());
|
||||
labels.addAll(update.getLabelsIfNew().stream()
|
||||
.filter(label -> !currentDocument.getLabels().containsKey(label.getLanguageCode())).collect(Collectors.toList()));
|
||||
TermUpdate labelUpdate = Datamodel.makeTermUpdate(labels, Collections.emptyList());
|
||||
StatementUpdate statementUpdate = Datamodel.makeStatementUpdate(update.getAddedStatements(), update.getDeletedStatements(),
|
||||
Collections.emptyList());
|
||||
MediaInfoUpdate updatesCollection = Datamodel.makeMediaInfoUpdate((MediaInfoIdValue) update.getItemId(),
|
||||
currentDocument.getRevisionId(), labelUpdate, statementUpdate);
|
||||
editor.editEntityDocument(updatesCollection, false, summary, tags);
|
||||
}
|
||||
}
|
||||
} catch (MediaWikiApiErrorException e) {
|
||||
// TODO find a way to report these errors to the user in a nice way
|
||||
|
@ -114,7 +114,7 @@ public class ReconEntityRewriter extends DatamodelConverter {
|
||||
return Datamodel.makeMediaInfoIdValue(newId, recon.getRecon().identifierSpace);
|
||||
}
|
||||
}
|
||||
return (MediaInfoIdValue) super.copy((ItemIdValue) value);
|
||||
return super.copy((MediaInfoIdValue) value);
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -1,24 +1,104 @@
|
||||
package org.openrefine.wikidata.manifests;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* A configuration object for a Wikibase instance.
|
||||
* The deserialization of this object is versioned, via {@link org.openrefine.wikidata.manifests.ManifestParser}.
|
||||
*
|
||||
* @author Lu Liu, Antonin Delpeuch
|
||||
*
|
||||
*/
|
||||
public interface Manifest {
|
||||
|
||||
public static final String ITEM_TYPE = "item";
|
||||
public static final String PROPERTY_TYPE = "property";
|
||||
public static final String MEDIAINFO_TYPE = "mediainfo";
|
||||
|
||||
/**
|
||||
* The version of the manifest object, which determines its JSON format.
|
||||
*/
|
||||
String getVersion();
|
||||
|
||||
/**
|
||||
* The name of the Wikibase instance, displayed in the UI.
|
||||
*/
|
||||
String getName();
|
||||
|
||||
/**
|
||||
* The RDF serialization prefix for entities stored in this instance.
|
||||
*/
|
||||
String getSiteIri();
|
||||
|
||||
/**
|
||||
* The recommended `maxlag` value for edits on this instance.
|
||||
*/
|
||||
int getMaxlag();
|
||||
|
||||
/**
|
||||
* The property id used to link an entity to the entity represing its type (class).
|
||||
* In Wikidata, this is P31 (instance of)
|
||||
*/
|
||||
String getInstanceOfPid();
|
||||
|
||||
/**
|
||||
* The property id used to link a class to its superclasses.
|
||||
* In Wikidata, this is P279 (subclass of)
|
||||
*/
|
||||
String getSubclassOfPid();
|
||||
|
||||
/**
|
||||
* The MediaWiki API endpoint of this Wikibase instance.
|
||||
*/
|
||||
String getMediaWikiApiEndpoint();
|
||||
|
||||
/**
|
||||
* The reconciliation service for items in this Wikibase instance.
|
||||
* @deprecated use {@link #getReconServiceEndpoint(String)} with "item" as argument
|
||||
*/
|
||||
String getReconServiceEndpoint();
|
||||
|
||||
/**
|
||||
* Get the reconciliation service endpoint for a given entity type supported by this Wikibase instance.
|
||||
* @param entityType
|
||||
* @return null if there is no recon service for this entity type.
|
||||
*/
|
||||
String getReconServiceEndpoint(String entityType);
|
||||
|
||||
/**
|
||||
* Get the MediaWiki endpoint of the source Wikibase for the entity type.
|
||||
* This can be different than the MediaWiki endpoint for this Wikibase instance,
|
||||
* when federation is used.
|
||||
* @param entityType
|
||||
* @return null if there is no recon service for this entity type.
|
||||
*/
|
||||
String getMediaWikiApiEndpoint(String entityType);
|
||||
|
||||
/**
|
||||
* Gets the site IRI used for a particular entity type.
|
||||
* - if the entity type is editable on this Wikibase instance, then it should be identical
|
||||
* to the site IRI for this instance.
|
||||
* - if the entity type is federated from another instance, then it should be the site IRI
|
||||
* for that instance.
|
||||
* @param entityType
|
||||
* @return null if the entity type is not supported by the Wikibase instance
|
||||
*/
|
||||
String getEntityTypeSiteIri(String entityType);
|
||||
|
||||
/**
|
||||
* The list of all entity types in use on this instance.
|
||||
*/
|
||||
List<String> getAvailableEntityTypes();
|
||||
|
||||
/**
|
||||
* Returns an item or property id used in the WikibaseQualityConstraints extension.
|
||||
* @param name our internal identifier for the entity id
|
||||
* @return the entity id
|
||||
*/
|
||||
String getConstraintsRelatedId(String name);
|
||||
|
||||
/**
|
||||
* Returns the template that should be inserted in edit summaries for edits to be tracked by EditGroups.
|
||||
*/
|
||||
String getEditGroupsUrlSchema();
|
||||
}
|
||||
|
@ -3,6 +3,9 @@ package org.openrefine.wikidata.manifests;
|
||||
import com.fasterxml.jackson.core.JsonProcessingException;
|
||||
import com.fasterxml.jackson.databind.JsonNode;
|
||||
import com.fasterxml.jackson.databind.ObjectMapper;
|
||||
|
||||
import java.io.IOException;
|
||||
|
||||
import org.apache.commons.lang3.StringUtils;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
@ -33,6 +36,12 @@ public final class ManifestParser {
|
||||
// support only v1.x for now
|
||||
if ("1".equals(majorVersion)) {
|
||||
return new ManifestV1(root);
|
||||
} else if ("2".equals(majorVersion)) {
|
||||
try {
|
||||
return new ManifestV2(root);
|
||||
} catch (IOException e) {
|
||||
throw new ManifestException("invalid manifest format: " + e.getMessage());
|
||||
}
|
||||
} else {
|
||||
throw new ManifestException("unsupported manifest version: " + version);
|
||||
}
|
||||
|
@ -1,12 +1,14 @@
|
||||
package org.openrefine.wikidata.manifests;
|
||||
|
||||
import com.fasterxml.jackson.databind.JsonNode;
|
||||
|
||||
import java.util.Arrays;
|
||||
import java.util.HashMap;
|
||||
import java.util.Iterator;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
import org.wikidata.wdtk.wikibaseapi.ApiConnection;
|
||||
import org.wikidata.wdtk.datamodel.interfaces.EntityIdValue;
|
||||
|
||||
import com.fasterxml.jackson.databind.JsonNode;
|
||||
|
||||
public class ManifestV1 implements Manifest {
|
||||
|
||||
@ -102,4 +104,30 @@ public class ManifestV1 implements Manifest {
|
||||
return editGroupsUrlSchema;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String getReconServiceEndpoint(String entityType) {
|
||||
if (ITEM_TYPE.equals(entityType)) {
|
||||
return reconServiceEndpoint;
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String getEntityTypeSiteIri(String entityType) {
|
||||
if (ITEM_TYPE.equals(entityType) || PROPERTY_TYPE.equals(entityType)) {
|
||||
return siteIri;
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String getMediaWikiApiEndpoint(String entityType) {
|
||||
return getMediaWikiApiEndpoint();
|
||||
}
|
||||
|
||||
@Override
|
||||
public List<String> getAvailableEntityTypes() {
|
||||
return Arrays.asList(ITEM_TYPE, PROPERTY_TYPE);
|
||||
}
|
||||
|
||||
}
|
||||
|
@ -23,6 +23,8 @@
|
||||
******************************************************************************/
|
||||
package org.openrefine.wikidata.schema;
|
||||
|
||||
import java.util.Map;
|
||||
|
||||
import org.apache.commons.lang.Validate;
|
||||
import org.openrefine.wikidata.qa.QAWarning;
|
||||
import org.openrefine.wikidata.qa.QAWarningStore;
|
||||
@ -42,6 +44,7 @@ import com.google.refine.model.Row;
|
||||
public class ExpressionContext {
|
||||
|
||||
private String baseIRI;
|
||||
private Map<String, String> entityTypeIRIs;
|
||||
private String mediaWikiApiEndpoint;
|
||||
private int rowId;
|
||||
private Row row;
|
||||
@ -53,6 +56,8 @@ public class ExpressionContext {
|
||||
*
|
||||
* @param baseIRI
|
||||
* the siteIRI of the schema
|
||||
* @param entityTypeBaseIRIS
|
||||
* the siteIRI for specific entity types, falling back on the baseIRI otherwise
|
||||
* @param mediaWikiApiEndpoint
|
||||
* the MediaWiki API endpoint of the Wikibase
|
||||
* @param rowId
|
||||
@ -65,9 +70,17 @@ public class ExpressionContext {
|
||||
* where to store the issues encountered when evaluating (can be set
|
||||
* to null if these issues should be ignored)
|
||||
*/
|
||||
public ExpressionContext(String baseIRI, String mediaWikiApiEndpoint, int rowId, Row row, ColumnModel columnModel, QAWarningStore warningStore) {
|
||||
public ExpressionContext(
|
||||
String baseIRI,
|
||||
Map<String, String> entityTypeBaseIRIs,
|
||||
String mediaWikiApiEndpoint,
|
||||
int rowId,
|
||||
Row row,
|
||||
ColumnModel columnModel,
|
||||
QAWarningStore warningStore) {
|
||||
Validate.notNull(baseIRI);
|
||||
this.baseIRI = baseIRI;
|
||||
this.entityTypeIRIs = entityTypeBaseIRIs;
|
||||
this.mediaWikiApiEndpoint = mediaWikiApiEndpoint;
|
||||
this.rowId = rowId;
|
||||
Validate.notNull(row);
|
||||
@ -81,6 +94,10 @@ public class ExpressionContext {
|
||||
return baseIRI;
|
||||
}
|
||||
|
||||
public String getBaseIRIForEntityType(String entityType) {
|
||||
return entityTypeIRIs.getOrDefault(entityType, baseIRI);
|
||||
}
|
||||
|
||||
public String getMediaWikiApiEndpoint() {
|
||||
return mediaWikiApiEndpoint;
|
||||
}
|
||||
|
@ -66,23 +66,33 @@ public class WbEntityVariable extends WbVariableExpr<EntityIdValue> {
|
||||
throws SkipSchemaExpressionException {
|
||||
if (cell.recon != null
|
||||
&& (Judgment.Matched.equals(cell.recon.judgment) || Judgment.New.equals(cell.recon.judgment))) {
|
||||
if (cell.recon.identifierSpace == null || !cell.recon.identifierSpace.equals(ctxt.getBaseIRI())) {
|
||||
QAWarning warning = new QAWarning("invalid-identifier-space", null, QAWarning.Severity.INFO, 1);
|
||||
warning.setProperty("example_cell", cell.value.toString());
|
||||
ctxt.addWarning(warning);
|
||||
throw new SkipSchemaExpressionException();
|
||||
}
|
||||
if (Judgment.New.equals(cell.recon.judgment)) {
|
||||
return new ReconItemIdValue(cell.recon, cell.value.toString());
|
||||
}
|
||||
EntityIdValue entityIdValue = EntityIdValueImpl.fromId(cell.recon.match.id, cell.recon.identifierSpace);
|
||||
EntityIdValue reconEntityIdValue = null;
|
||||
String entityType = null;
|
||||
if (entityIdValue instanceof ItemIdValue) {
|
||||
return new ReconItemIdValue(cell.recon, cell.value.toString());
|
||||
reconEntityIdValue = new ReconItemIdValue(cell.recon, cell.value.toString());
|
||||
entityType = "item";
|
||||
} else if (entityIdValue instanceof MediaInfoIdValue) {
|
||||
return new ReconMediaInfoIdValue(cell.recon, cell.value.toString());
|
||||
reconEntityIdValue = new ReconMediaInfoIdValue(cell.recon, cell.value.toString());
|
||||
entityType = "mediainfo";
|
||||
} else if (entityIdValue instanceof PropertyIdValue) {
|
||||
return new ReconPropertyIdValue(cell.recon, cell.value.toString());
|
||||
reconEntityIdValue = new ReconPropertyIdValue(cell.recon, cell.value.toString());
|
||||
entityType = "property";
|
||||
}
|
||||
if (reconEntityIdValue == null) {
|
||||
throw new SkipSchemaExpressionException();
|
||||
}
|
||||
if (cell.recon.identifierSpace == null || !cell.recon.identifierSpace.equals(ctxt.getBaseIRIForEntityType(entityType))) {
|
||||
QAWarning warning = new QAWarning("invalid-identifier-space", null, QAWarning.Severity.INFO, 1);
|
||||
warning.setProperty("example_cell", cell.value.toString());
|
||||
warning.setProperty("expected_site_iri", ctxt.getBaseIRIForEntityType(entityType));
|
||||
ctxt.addWarning(warning);
|
||||
throw new SkipSchemaExpressionException();
|
||||
}
|
||||
return reconEntityIdValue;
|
||||
}
|
||||
throw new SkipSchemaExpressionException();
|
||||
}
|
||||
|
@ -47,6 +47,7 @@ import com.fasterxml.jackson.annotation.JsonTypeInfo;
|
||||
@Type(value = WbDateVariable.class, name = "wbdatevariable"),
|
||||
@Type(value = WbMonolingualExpr.class, name = "wbmonolingualexpr"),
|
||||
@Type(value = WbPropConstant.class, name = "wbpropconstant"),
|
||||
@Type(value = WbEntityIdValueConstant.class, name = "wbentityidvalueconstant"),
|
||||
@Type(value = WbLanguageConstant.class, name = "wblanguageconstant"),
|
||||
@Type(value = WbLanguageVariable.class, name = "wblanguagevariable"),
|
||||
@Type(value = WbQuantityExpr.class, name = "wbquantityexpr"), })
|
||||
|
@ -29,7 +29,7 @@ import java.util.List;
|
||||
import org.jsoup.helper.Validate;
|
||||
import org.openrefine.wikidata.schema.exceptions.SkipSchemaExpressionException;
|
||||
import org.openrefine.wikidata.updates.TermedStatementEntityUpdate;
|
||||
import org.openrefine.wikidata.updates.ItemUpdateBuilder;
|
||||
import org.openrefine.wikidata.updates.TermedStatementEntityUpdateBuilder;
|
||||
import org.wikidata.wdtk.datamodel.interfaces.EntityIdValue;
|
||||
import org.wikidata.wdtk.datamodel.interfaces.ItemIdValue;
|
||||
import org.wikidata.wdtk.datamodel.interfaces.Statement;
|
||||
@ -74,7 +74,7 @@ public class WbItemDocumentExpr implements WbExpression<TermedStatementEntityUpd
|
||||
public TermedStatementEntityUpdate evaluate(ExpressionContext ctxt)
|
||||
throws SkipSchemaExpressionException {
|
||||
EntityIdValue subjectId = getSubject().evaluate(ctxt);
|
||||
ItemUpdateBuilder update = new ItemUpdateBuilder(subjectId);
|
||||
TermedStatementEntityUpdateBuilder update = new TermedStatementEntityUpdateBuilder(subjectId);
|
||||
for (WbStatementGroupExpr expr : getStatementGroups()) {
|
||||
try {
|
||||
for (Statement s : expr.evaluate(ctxt, subjectId).getStatements()) {
|
||||
|
@ -25,7 +25,7 @@ package org.openrefine.wikidata.schema;
|
||||
|
||||
import org.jsoup.helper.Validate;
|
||||
import org.openrefine.wikidata.schema.exceptions.SkipSchemaExpressionException;
|
||||
import org.openrefine.wikidata.updates.ItemUpdateBuilder;
|
||||
import org.openrefine.wikidata.updates.TermedStatementEntityUpdateBuilder;
|
||||
import org.wikidata.wdtk.datamodel.interfaces.MonolingualTextValue;
|
||||
|
||||
import com.fasterxml.jackson.annotation.JsonCreator;
|
||||
@ -35,7 +35,7 @@ import com.fasterxml.jackson.annotation.JsonProperty;
|
||||
/**
|
||||
* An expression that represent a term (label, description or alias). The
|
||||
* structure is slightly different from other expressions because we need to
|
||||
* call different methods on {@link ItemUpdateBuilder}.
|
||||
* call different methods on {@link TermedStatementEntityUpdateBuilder}.
|
||||
*
|
||||
* @author Antonin Delpeuch
|
||||
*
|
||||
@ -67,7 +67,7 @@ public class WbNameDescExpr {
|
||||
* @param ctxt
|
||||
* the evaluation context for the expression
|
||||
*/
|
||||
public void contributeTo(ItemUpdateBuilder item, ExpressionContext ctxt) {
|
||||
public void contributeTo(TermedStatementEntityUpdateBuilder item, ExpressionContext ctxt) {
|
||||
try {
|
||||
MonolingualTextValue val = getValue().evaluate(ctxt);
|
||||
switch (getType()) {
|
||||
|
@ -27,6 +27,7 @@ import java.io.IOException;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Collections;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
import org.openrefine.wikidata.qa.QAWarningStore;
|
||||
import org.openrefine.wikidata.schema.exceptions.SkipSchemaExpressionException;
|
||||
@ -64,14 +65,18 @@ public class WikibaseSchema implements OverlayModel {
|
||||
@JsonProperty("siteIri")
|
||||
protected String siteIri;
|
||||
|
||||
@JsonProperty("entityTypeSiteIRI")
|
||||
protected Map<String, String> entityTypeSiteIri;
|
||||
|
||||
@JsonProperty("mediaWikiApiEndpoint")
|
||||
protected String mediaWikiApiEndpoint;
|
||||
|
||||
/**
|
||||
* Constructor.
|
||||
* @todo remove this, it does not create a valid schema.
|
||||
*/
|
||||
public WikibaseSchema() {
|
||||
|
||||
entityTypeSiteIri = Collections.emptyMap();
|
||||
}
|
||||
|
||||
/**
|
||||
@ -80,9 +85,11 @@ public class WikibaseSchema implements OverlayModel {
|
||||
@JsonCreator
|
||||
public WikibaseSchema(@JsonProperty("itemDocuments") List<WbItemDocumentExpr> exprs,
|
||||
@JsonProperty("siteIri") String siteIri,
|
||||
@JsonProperty("entityTypeSiteIRI") Map<String, String> entityTypeSiteIri,
|
||||
@JsonProperty("mediaWikiApiEndpoint") String mediaWikiApiEndpoint) {
|
||||
this.itemDocumentExprs = exprs;
|
||||
this.siteIri = siteIri;
|
||||
this.entityTypeSiteIri = entityTypeSiteIri != null ? entityTypeSiteIri : Collections.emptyMap();
|
||||
this.mediaWikiApiEndpoint = mediaWikiApiEndpoint != null ? mediaWikiApiEndpoint : ApiConnection.URL_WIKIDATA_API;
|
||||
}
|
||||
|
||||
@ -94,6 +101,14 @@ public class WikibaseSchema implements OverlayModel {
|
||||
return siteIri;
|
||||
}
|
||||
|
||||
/**
|
||||
* @return the site IRI of the Wikibase instance referenced by this schema
|
||||
*/
|
||||
@JsonProperty("entityTypeSiteIRI")
|
||||
public Map<String, String> getEntityTypeSiteIri() {
|
||||
return entityTypeSiteIri;
|
||||
}
|
||||
|
||||
/**
|
||||
* @return the list of document expressions for this schema
|
||||
*/
|
||||
@ -177,7 +192,7 @@ public class WikibaseSchema implements OverlayModel {
|
||||
|
||||
@Override
|
||||
public boolean visit(Project project, int rowIndex, Row row) {
|
||||
ExpressionContext ctxt = new ExpressionContext(siteIri, mediaWikiApiEndpoint, rowIndex, row, project.columnModel, warningStore);
|
||||
ExpressionContext ctxt = new ExpressionContext(siteIri, entityTypeSiteIri, mediaWikiApiEndpoint, rowIndex, row, project.columnModel, warningStore);
|
||||
result.addAll(evaluateItemDocuments(ctxt));
|
||||
return false;
|
||||
}
|
||||
|
@ -33,6 +33,11 @@ public class ReconItemIdValue extends ReconEntityIdValue implements ItemIdValue
|
||||
super(recon, cellValue);
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean isPlaceholder() {
|
||||
return isNew();
|
||||
}
|
||||
|
||||
@Override
|
||||
public String getEntityType() {
|
||||
return ET_ITEM;
|
||||
|
@ -34,6 +34,11 @@ public class ReconMediaInfoIdValue extends ReconEntityIdValue implements MediaIn
|
||||
super(recon, cellValue);
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean isPlaceholder() {
|
||||
return isNew();
|
||||
}
|
||||
|
||||
@Override
|
||||
public String getEntityType() {
|
||||
return EntityIdValue.ET_MEDIA_INFO;
|
||||
|
@ -33,6 +33,11 @@ public class ReconPropertyIdValue extends ReconEntityIdValue implements Property
|
||||
super(recon, cellValue);
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean isPlaceholder() {
|
||||
return isNew();
|
||||
}
|
||||
|
||||
@Override
|
||||
public String getEntityType() {
|
||||
return ET_PROPERTY;
|
||||
|
@ -27,6 +27,8 @@ import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
import org.wikidata.wdtk.datamodel.helpers.Hash;
|
||||
import org.wikidata.wdtk.datamodel.implementation.EntityIdValueImpl;
|
||||
import org.wikidata.wdtk.datamodel.interfaces.DatatypeIdValue;
|
||||
import org.wikidata.wdtk.datamodel.interfaces.EntityIdValue;
|
||||
import org.wikidata.wdtk.datamodel.interfaces.ValueVisitor;
|
||||
|
||||
@ -51,6 +53,26 @@ public abstract class SuggestedEntityIdValue implements PrefetchedEntityIdValue
|
||||
_label = label;
|
||||
}
|
||||
|
||||
public static SuggestedEntityIdValue build(String id, String siteIRI, String label) {
|
||||
String entityType = EntityIdValueImpl.guessEntityTypeFromId(id);
|
||||
if (DatatypeIdValue.DT_ITEM.equals(entityType)) {
|
||||
return new SuggestedItemIdValue(id, siteIRI, label);
|
||||
} else if (DatatypeIdValue.DT_PROPERTY.equals(entityType)) {
|
||||
return new SuggestedPropertyIdValue(id, siteIRI, label);
|
||||
} else if (DatatypeIdValue.DT_MEDIA_INFO.equals(entityType)) {
|
||||
return new SuggestedMediaInfoIdValue(id, siteIRI, label);
|
||||
} else if (DatatypeIdValue.DT_LEXEME.equals(entityType)) {
|
||||
return new SuggestedLexemeIdValue(id, siteIRI, label);
|
||||
} else if (DatatypeIdValue.DT_FORM.equals(entityType)) {
|
||||
return new SuggestedFormIdValue(id, siteIRI, label);
|
||||
} else if (DatatypeIdValue.DT_SENSE.equals(entityType)) {
|
||||
return new SuggestedSenseIdValue(id, siteIRI, label);
|
||||
} else {
|
||||
throw new IllegalArgumentException(
|
||||
String.format("Unsupported datatype for suggested entity values: %s", entityType));
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
@JsonProperty("id")
|
||||
public String getId() {
|
||||
@ -81,6 +103,11 @@ public abstract class SuggestedEntityIdValue implements PrefetchedEntityIdValue
|
||||
return getSiteIri() + getId();
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean isPlaceholder() {
|
||||
return false;
|
||||
}
|
||||
|
||||
@Override
|
||||
public <T> T accept(ValueVisitor<T> valueVisitor) {
|
||||
return valueVisitor.visit(this);
|
||||
@ -100,4 +127,9 @@ public abstract class SuggestedEntityIdValue implements PrefetchedEntityIdValue
|
||||
return Hash.hashCode(this);
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return getIri();
|
||||
}
|
||||
|
||||
}
|
||||
|
@ -1,233 +0,0 @@
|
||||
/*******************************************************************************
|
||||
* MIT License
|
||||
*
|
||||
* Copyright (c) 2018 Antonin Delpeuch
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
* of this software and associated documentation files (the "Software"), to deal
|
||||
* in the Software without restriction, including without limitation the rights
|
||||
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
* copies of the Software, and to permit persons to whom the Software is
|
||||
* furnished to do so, subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice shall be included in all
|
||||
* copies or substantial portions of the Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||
* SOFTWARE.
|
||||
******************************************************************************/
|
||||
package org.openrefine.wikidata.updates;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.HashSet;
|
||||
import java.util.List;
|
||||
import java.util.Set;
|
||||
|
||||
import org.jsoup.helper.Validate;
|
||||
import org.wikidata.wdtk.datamodel.interfaces.EntityIdValue;
|
||||
import org.wikidata.wdtk.datamodel.interfaces.ItemIdValue;
|
||||
import org.wikidata.wdtk.datamodel.interfaces.MonolingualTextValue;
|
||||
import org.wikidata.wdtk.datamodel.interfaces.Statement;
|
||||
|
||||
/**
|
||||
* Constructs a {@link ItemUpdate} incrementally.
|
||||
*
|
||||
* @author Antonin Delpeuch
|
||||
*
|
||||
*/
|
||||
public class ItemUpdateBuilder {
|
||||
|
||||
private EntityIdValue qid;
|
||||
private List<Statement> addedStatements;
|
||||
private Set<Statement> deletedStatements;
|
||||
private Set<MonolingualTextValue> labels;
|
||||
private Set<MonolingualTextValue> labelsIfNew;
|
||||
private Set<MonolingualTextValue> descriptions;
|
||||
private Set<MonolingualTextValue> descriptionsIfNew;
|
||||
private Set<MonolingualTextValue> aliases;
|
||||
private boolean built;
|
||||
|
||||
/**
|
||||
* Constructor.
|
||||
*
|
||||
* @param qid
|
||||
* the subject of the document. It can be a reconciled item value for
|
||||
* new items.
|
||||
*/
|
||||
public ItemUpdateBuilder(EntityIdValue qid) {
|
||||
Validate.notNull(qid);
|
||||
this.qid = qid;
|
||||
this.addedStatements = new ArrayList<>();
|
||||
this.deletedStatements = new HashSet<Statement>();
|
||||
this.labels = new HashSet<MonolingualTextValue>();
|
||||
this.labelsIfNew = new HashSet<MonolingualTextValue>();
|
||||
this.descriptions = new HashSet<MonolingualTextValue>();
|
||||
this.descriptionsIfNew = new HashSet<MonolingualTextValue>();
|
||||
this.aliases = new HashSet<MonolingualTextValue>();
|
||||
this.built = false;
|
||||
}
|
||||
|
||||
/**
|
||||
* Mark a statement for insertion. If it matches an existing statement, it will
|
||||
* update the statement instead.
|
||||
*
|
||||
* @param statement
|
||||
* the statement to add or update
|
||||
*/
|
||||
public ItemUpdateBuilder addStatement(Statement statement) {
|
||||
Validate.isTrue(!built, "ItemUpdate has already been built");
|
||||
addedStatements.add(statement);
|
||||
return this;
|
||||
}
|
||||
|
||||
/**
|
||||
* Mark a statement for deletion. If no such statement exists, nothing will be
|
||||
* deleted.
|
||||
*
|
||||
* @param statement
|
||||
* the statement to delete
|
||||
*/
|
||||
public ItemUpdateBuilder deleteStatement(Statement statement) {
|
||||
Validate.isTrue(!built, "ItemUpdate has already been built");
|
||||
deletedStatements.add(statement);
|
||||
return this;
|
||||
}
|
||||
|
||||
/**
|
||||
* Add a list of statement, as in {@link addStatement}.
|
||||
*
|
||||
* @param statements
|
||||
* the statements to add
|
||||
*/
|
||||
public ItemUpdateBuilder addStatements(Set<Statement> statements) {
|
||||
Validate.isTrue(!built, "ItemUpdate has already been built");
|
||||
addedStatements.addAll(statements);
|
||||
return this;
|
||||
}
|
||||
|
||||
/**
|
||||
* Delete a list of statements, as in {@link deleteStatement}.
|
||||
*
|
||||
* @param statements
|
||||
* the statements to delete
|
||||
*/
|
||||
public ItemUpdateBuilder deleteStatements(Set<Statement> statements) {
|
||||
Validate.isTrue(!built, "ItemUpdate has already been built");
|
||||
deletedStatements.addAll(statements);
|
||||
return this;
|
||||
}
|
||||
|
||||
/**
|
||||
* Adds a label to the item.
|
||||
*
|
||||
* @param label
|
||||
* the label to add
|
||||
* @param override
|
||||
* whether the label should be added even if there is already a label in that language
|
||||
*/
|
||||
public ItemUpdateBuilder addLabel(MonolingualTextValue label, boolean override) {
|
||||
Validate.isTrue(!built, "ItemUpdate has already been built");
|
||||
if (override) {
|
||||
labels.add(label);
|
||||
} else {
|
||||
labelsIfNew.add(label);
|
||||
}
|
||||
return this;
|
||||
}
|
||||
|
||||
/**
|
||||
* Adds a list of labels to the item.
|
||||
*
|
||||
* @param labels
|
||||
* the labels to add
|
||||
* @param override
|
||||
* whether the label should be added even if there is already a label in that language
|
||||
*/
|
||||
public ItemUpdateBuilder addLabels(Set<MonolingualTextValue> labels, boolean override) {
|
||||
Validate.isTrue(!built, "ItemUpdate has already been built");
|
||||
if (override) {
|
||||
this.labels.addAll(labels);
|
||||
} else {
|
||||
labelsIfNew.addAll(labels);
|
||||
}
|
||||
return this;
|
||||
}
|
||||
|
||||
/**
|
||||
* Adds a description to the item.
|
||||
*
|
||||
* @param description
|
||||
* the description to add
|
||||
* @param override
|
||||
* whether the description should be added even if there is already a description in that language
|
||||
*/
|
||||
public ItemUpdateBuilder addDescription(MonolingualTextValue description, boolean override) {
|
||||
Validate.isTrue(!built, "ItemUpdate has already been built");
|
||||
if (override) {
|
||||
descriptions.add(description);
|
||||
} else {
|
||||
descriptionsIfNew.add(description);
|
||||
}
|
||||
return this;
|
||||
}
|
||||
|
||||
/**
|
||||
* Adds a list of descriptions to the item.
|
||||
*
|
||||
* @param descriptions
|
||||
* the descriptions to add
|
||||
* @param override
|
||||
* whether the description should be added even if there is already a description in that language
|
||||
*/
|
||||
public ItemUpdateBuilder addDescriptions(Set<MonolingualTextValue> descriptions, boolean override) {
|
||||
Validate.isTrue(!built, "ItemUpdate has already been built");
|
||||
if (override) {
|
||||
this.descriptions.addAll(descriptions);
|
||||
} else {
|
||||
descriptionsIfNew.addAll(descriptions);
|
||||
}
|
||||
return this;
|
||||
}
|
||||
|
||||
/**
|
||||
* Adds an alias to the item. It will be added to any existing aliases in that
|
||||
* language.
|
||||
*
|
||||
* @param alias
|
||||
* the alias to add
|
||||
*/
|
||||
public ItemUpdateBuilder addAlias(MonolingualTextValue alias) {
|
||||
Validate.isTrue(!built, "ItemUpdate has already been built");
|
||||
aliases.add(alias);
|
||||
return this;
|
||||
}
|
||||
|
||||
/**
|
||||
* Adds a list of aliases to the item. They will be added to any existing
|
||||
* aliases in each language.
|
||||
*
|
||||
* @param aliases
|
||||
* the aliases to add
|
||||
*/
|
||||
public ItemUpdateBuilder addAliases(Set<MonolingualTextValue> aliases) {
|
||||
Validate.isTrue(!built, "ItemUpdate has already been built");
|
||||
this.aliases.addAll(aliases);
|
||||
return this;
|
||||
}
|
||||
|
||||
/**
|
||||
* Constructs the {@link ItemUpdate}.
|
||||
*
|
||||
* @return
|
||||
*/
|
||||
public TermedStatementEntityUpdate build() {
|
||||
built = true;
|
||||
return new TermedStatementEntityUpdate(qid, addedStatements, deletedStatements, labels, labelsIfNew, descriptions, descriptionsIfNew, aliases);
|
||||
}
|
||||
|
||||
}
|
@ -33,7 +33,7 @@ import java.util.Set;
|
||||
|
||||
import org.openrefine.wikidata.schema.entityvalues.ReconItemIdValue;
|
||||
import org.openrefine.wikidata.updates.TermedStatementEntityUpdate;
|
||||
import org.openrefine.wikidata.updates.ItemUpdateBuilder;
|
||||
import org.openrefine.wikidata.updates.TermedStatementEntityUpdateBuilder;
|
||||
import org.wikidata.wdtk.datamodel.interfaces.ItemIdValue;
|
||||
import org.wikidata.wdtk.datamodel.interfaces.Statement;
|
||||
|
||||
@ -64,14 +64,14 @@ public class QuickStatementsUpdateScheduler implements UpdateScheduler {
|
||||
*/
|
||||
protected void splitUpdate(TermedStatementEntityUpdate update)
|
||||
throws ImpossibleSchedulingException {
|
||||
ItemUpdateBuilder remainingUpdateBuilder = new ItemUpdateBuilder(update.getItemId())
|
||||
TermedStatementEntityUpdateBuilder remainingUpdateBuilder = new TermedStatementEntityUpdateBuilder(update.getItemId())
|
||||
.addLabels(update.getLabels(), true)
|
||||
.addLabels(update.getLabelsIfNew(), false)
|
||||
.addDescriptions(update.getDescriptions(), true)
|
||||
.addDescriptions(update.getDescriptionsIfNew(), false)
|
||||
.addAliases(update.getAliases())
|
||||
.deleteStatements(update.getDeletedStatements());
|
||||
Map<ItemIdValue, ItemUpdateBuilder> referencingUpdates = new HashMap<>();
|
||||
Map<ItemIdValue, TermedStatementEntityUpdateBuilder> referencingUpdates = new HashMap<>();
|
||||
|
||||
for (Statement statement : update.getAddedStatements()) {
|
||||
Set<ReconItemIdValue> pointers = extractor.extractPointers(statement);
|
||||
@ -79,9 +79,9 @@ public class QuickStatementsUpdateScheduler implements UpdateScheduler {
|
||||
remainingUpdateBuilder.addStatement(statement);
|
||||
} else if (pointers.size() == 1 && !update.isNew()) {
|
||||
ItemIdValue pointer = pointers.stream().findFirst().get();
|
||||
ItemUpdateBuilder referencingBuilder = referencingUpdates.get(pointer);
|
||||
TermedStatementEntityUpdateBuilder referencingBuilder = referencingUpdates.get(pointer);
|
||||
if (referencingBuilder == null) {
|
||||
referencingBuilder = new ItemUpdateBuilder(update.getItemId());
|
||||
referencingBuilder = new TermedStatementEntityUpdateBuilder(update.getItemId());
|
||||
}
|
||||
referencingBuilder.addStatement(statement);
|
||||
referencingUpdates.put(pointer, referencingBuilder);
|
||||
@ -98,7 +98,7 @@ public class QuickStatementsUpdateScheduler implements UpdateScheduler {
|
||||
pointerFreeUpdates.add(pointerFree);
|
||||
}
|
||||
// Add the other updates to the map
|
||||
for (Entry<ItemIdValue, ItemUpdateBuilder> entry : referencingUpdates.entrySet()) {
|
||||
for (Entry<ItemIdValue, TermedStatementEntityUpdateBuilder> entry : referencingUpdates.entrySet()) {
|
||||
TermedStatementEntityUpdate pointerUpdate = entry.getValue().build();
|
||||
UpdateSequence pointerUpdatesForKey = pointerUpdates.get(entry.getKey());
|
||||
if (pointerUpdatesForKey == null) {
|
||||
@ -135,7 +135,7 @@ public class QuickStatementsUpdateScheduler implements UpdateScheduler {
|
||||
// (this is just for the sake of correctness, it would be bad to do that
|
||||
// as the items would remain blank in this batch).
|
||||
for (ItemIdValue missingId : mentionedNewEntities) {
|
||||
fullSchedule.add(new ItemUpdateBuilder(missingId).build());
|
||||
fullSchedule.add(new TermedStatementEntityUpdateBuilder(missingId).build());
|
||||
fullSchedule.addAll(pointerUpdates.get(missingId).getUpdates());
|
||||
}
|
||||
return fullSchedule;
|
||||
|
@ -48,7 +48,7 @@ public class UpdateSequence {
|
||||
/**
|
||||
* An index to keep track of where each item is touched in the sequence
|
||||
*/
|
||||
private Map<ItemIdValue, Integer> index = new HashMap<>();
|
||||
private Map<EntityIdValue, Integer> index = new HashMap<>();
|
||||
|
||||
/**
|
||||
* Adds a new update to the list, merging it with any existing one with the same
|
||||
@ -63,7 +63,7 @@ public class UpdateSequence {
|
||||
TermedStatementEntityUpdate oldUpdate = updates.get(i);
|
||||
updates.set(i, oldUpdate.merge(update));
|
||||
} else {
|
||||
index.put((ItemIdValue) subject, updates.size());
|
||||
index.put(subject, updates.size());
|
||||
updates.add(update);
|
||||
}
|
||||
}
|
||||
@ -78,7 +78,7 @@ public class UpdateSequence {
|
||||
/**
|
||||
* @return the set of touched subjects
|
||||
*/
|
||||
public Set<ItemIdValue> getSubjects() {
|
||||
public Set<EntityIdValue> getSubjects() {
|
||||
return index.keySet();
|
||||
}
|
||||
}
|
||||
|
@ -31,7 +31,7 @@ import java.util.stream.Collectors;
|
||||
|
||||
import org.openrefine.wikidata.schema.entityvalues.ReconItemIdValue;
|
||||
import org.openrefine.wikidata.updates.TermedStatementEntityUpdate;
|
||||
import org.openrefine.wikidata.updates.ItemUpdateBuilder;
|
||||
import org.openrefine.wikidata.updates.TermedStatementEntityUpdateBuilder;
|
||||
import org.wikidata.wdtk.datamodel.interfaces.ItemIdValue;
|
||||
import org.wikidata.wdtk.datamodel.interfaces.Statement;
|
||||
|
||||
@ -84,7 +84,7 @@ public class WikibaseAPIUpdateScheduler implements UpdateScheduler {
|
||||
Set<ItemIdValue> unseenPointers = new HashSet<>(allPointers);
|
||||
unseenPointers.removeAll(pointerFreeUpdates.getSubjects());
|
||||
|
||||
result.addAll(unseenPointers.stream().map(e -> new ItemUpdateBuilder(e).build()).collect(Collectors.toList()));
|
||||
result.addAll(unseenPointers.stream().map(e -> new TermedStatementEntityUpdateBuilder(e).build()).collect(Collectors.toList()));
|
||||
|
||||
// Part 2: add all the pointer full updates
|
||||
result.addAll(pointerFullUpdates.getUpdates());
|
||||
@ -98,14 +98,14 @@ public class WikibaseAPIUpdateScheduler implements UpdateScheduler {
|
||||
* @param update
|
||||
*/
|
||||
protected void splitUpdate(TermedStatementEntityUpdate update) {
|
||||
ItemUpdateBuilder pointerFreeBuilder = new ItemUpdateBuilder(update.getItemId())
|
||||
TermedStatementEntityUpdateBuilder pointerFreeBuilder = new TermedStatementEntityUpdateBuilder(update.getItemId())
|
||||
.addLabels(update.getLabels(), true)
|
||||
.addLabels(update.getLabelsIfNew(), false)
|
||||
.addDescriptions(update.getDescriptions(), true)
|
||||
.addDescriptions(update.getDescriptionsIfNew(), false)
|
||||
.addAliases(update.getAliases())
|
||||
.deleteStatements(update.getDeletedStatements());
|
||||
ItemUpdateBuilder pointerFullBuilder = new ItemUpdateBuilder(update.getItemId());
|
||||
TermedStatementEntityUpdateBuilder pointerFullBuilder = new TermedStatementEntityUpdateBuilder(update.getItemId());
|
||||
|
||||
for (Statement statement : update.getAddedStatements()) {
|
||||
Set<ReconItemIdValue> pointers = extractor.extractPointers(statement);
|
||||
|
@ -85,6 +85,12 @@ public class EntityCache {
|
||||
return cache.apply(id.getId());
|
||||
}
|
||||
|
||||
/**
|
||||
* Get an entity cache for a given Wikibase instance.
|
||||
* @param siteIri
|
||||
* @param mediaWikiApiEndpoint
|
||||
* @return
|
||||
*/
|
||||
public static EntityCache getEntityCache(String siteIri, String mediaWikiApiEndpoint) {
|
||||
EntityCache entityCache = entityCacheMap.get(siteIri);
|
||||
if (entityCache == null) {
|
||||
@ -94,6 +100,15 @@ public class EntityCache {
|
||||
return entityCache;
|
||||
}
|
||||
|
||||
/**
|
||||
* Provided for testability.
|
||||
* @param siteIri
|
||||
* @param cache
|
||||
*/
|
||||
public static void setEntityCache(String siteIri, EntityCache cache) {
|
||||
entityCacheMap.put(siteIri, cache);
|
||||
}
|
||||
|
||||
public List<EntityDocument> getMultipleDocuments(List<EntityIdValue> entityIds) throws ExecutionException {
|
||||
List<String> ids = entityIds.stream().map(entityId -> entityId.getId()).collect(Collectors.toList());
|
||||
return cache.getAll(ids).values().stream().collect(Collectors.toList());
|
||||
@ -102,4 +117,8 @@ public class EntityCache {
|
||||
public static EntityDocument getEntityDocument(String entityPrefix, String mediaWikiApiEndpoint, EntityIdValue id) {
|
||||
return getEntityCache(entityPrefix, mediaWikiApiEndpoint).get(id);
|
||||
}
|
||||
|
||||
public static void removeEntityCache(String siteIri) {
|
||||
entityCacheMap.remove(siteIri);
|
||||
}
|
||||
}
|
||||
|
@ -0,0 +1,46 @@
|
||||
{
|
||||
"version": "2.0",
|
||||
"mediawiki": {
|
||||
"name": "Wikimedia Commons",
|
||||
"root": "https://commons.wikimedia.org/wiki/",
|
||||
"main_page": "https://commons.wikimedia.org/wiki/Main_Page",
|
||||
"api": "https://commons.wikimedia.org/w/api.php"
|
||||
},
|
||||
"wikibase": {
|
||||
"site_iri": "https://commons.wikimedia.org/entity/",
|
||||
"maxlag": 5,
|
||||
"properties": {
|
||||
"instance_of": "P31",
|
||||
"subclass_of": "P279"
|
||||
},
|
||||
"constraints": {
|
||||
"property_constraint_pid": "P2302",
|
||||
"exception_to_constraint_pid": "P2303",
|
||||
"constraint_status_pid": "P2316",
|
||||
"mandatory_constraint_qid": "Q21502408",
|
||||
"suggestion_constraint_qid": "Q62026391",
|
||||
"distinct_values_constraint_qid": "Q21502410"
|
||||
}
|
||||
},
|
||||
"oauth": {
|
||||
"registration_page": "https://commons.wikimedia.org/wiki/Special:OAuthConsumerRegistration/propose"
|
||||
},
|
||||
"entity_types": {
|
||||
"item": {
|
||||
"site_iri": "http://www.wikidata.org/entity/",
|
||||
"reconciliation_endpoint": "https://wikidata.reconci.link/${lang}/api",
|
||||
"mediawiki_api": "https://www.wikidata.org/w/api.php"
|
||||
},
|
||||
"property": {
|
||||
"site_iri": "http://www.wikidata.org/entity/",
|
||||
"mediawiki_api": "https://www.wikidata.org/w/api.php"
|
||||
},
|
||||
"mediainfo": {
|
||||
"site_iri": "https://commons.wikimedia.org/entity/",
|
||||
"reconciliation_endpoint": "https://commonsreconcile.toolforge.org/${lang}/api"
|
||||
}
|
||||
},
|
||||
"editgroups": {
|
||||
"url_schema": "([[:toollabs:editgroups-commons/b/OR/${batch_id}|details]])"
|
||||
}
|
||||
}
|
@ -30,6 +30,7 @@
|
||||
}
|
||||
],
|
||||
"siteIri": "http://www.wikidata.org/entity/",
|
||||
"mediaWikiApiEndpoint":"https://www.wikidata.org/w/api.php"
|
||||
"mediaWikiApiEndpoint":"https://www.wikidata.org/w/api.php",
|
||||
"entityTypeSiteIRI": {}
|
||||
}
|
||||
}
|
||||
|
@ -1 +1 @@
|
||||
{"itemDocuments":[{"subject":{"type":"wbitemvariable","columnName":"name"},"statementGroups":[{"property":{"datatype":"wikibase-item","pid":"P39","label":"position held","type":"wbpropconstant"},"statements":[{"references":[{"snaks":[{"prop":{"datatype":"wikibase-item","pid":"P248","label":"stated in","type":"wbpropconstant"},"value":{"label":"The History of The Royal Society of Medicine","type":"wbitemconstant","qid":"Q42036099"}},{"prop":{"datatype":"string","pid":"P304","label":"page","type":"wbpropconstant"},"value":{"type":"wbstringconstant","value":"330-333"}}]}],"qualifiers":[{"prop":{"datatype":"wikibase-item","pid":"P642","label":"of","type":"wbpropconstant"},"value":{"label":"History of Medicine Society","type":"wbitemconstant","qid":"Q37461404"}},{"prop":{"datatype":"time","pid":"P580","label":"start date","type":"wbpropconstant"},"value":{"type":"wbdatevariable","columnName":"start"}},{"prop":{"datatype":"time","pid":"P582","label":"end date","type":"wbpropconstant"},"value":{"type":"wbdatevariable","columnName":"end"}}],"value":{"label":"president","type":"wbitemconstant","qid":"Q30461"}}]}],"nameDescs":[]},{"subject":{"label":"History of Medicine Society","type":"wbitemconstant","qid":"Q37461404"},"statementGroups":[{"property":{"datatype":"wikibase-item","pid":"P488","label":"chairperson","type":"wbpropconstant"},"statements":[{"references":[{"snaks":[{"prop":{"datatype":"wikibase-item","pid":"P248","label":"stated in","type":"wbpropconstant"},"value":{"label":"The History of The Royal Society of Medicine","type":"wbitemconstant","qid":"Q42036099"}},{"prop":{"datatype":"string","pid":"P304","label":"page","type":"wbpropconstant"},"value":{"type":"wbstringconstant","value":"330-333"}}]}],"qualifiers":[{"prop":{"datatype":"time","pid":"P580","label":"start date","type":"wbpropconstant"},"value":{"type":"wbdatevariable","columnName":"start"}},{"prop":{"datatype":"time","pid":"P582","label":"end date","type":"wbpropconstant"},"value":{"type":"wbdatevariable","columnName":"end"}}],"value":{"type":"wbitemvariable","columnName":"name"}}]}],"nameDescs":[]}],"siteIri":"http://www.wikidata.org/entity/","mediaWikiApiEndpoint":"https://www.wikidata.org/w/api.php"}
|
||||
{"itemDocuments":[{"subject":{"type":"wbitemvariable","columnName":"name"},"statementGroups":[{"property":{"datatype":"wikibase-item","pid":"P39","label":"position held","type":"wbpropconstant"},"statements":[{"references":[{"snaks":[{"prop":{"datatype":"wikibase-item","pid":"P248","label":"stated in","type":"wbpropconstant"},"value":{"label":"The History of The Royal Society of Medicine","type":"wbitemconstant","qid":"Q42036099"}},{"prop":{"datatype":"string","pid":"P304","label":"page","type":"wbpropconstant"},"value":{"type":"wbstringconstant","value":"330-333"}}]}],"qualifiers":[{"prop":{"datatype":"wikibase-item","pid":"P642","label":"of","type":"wbpropconstant"},"value":{"label":"History of Medicine Society","type":"wbitemconstant","qid":"Q37461404"}},{"prop":{"datatype":"time","pid":"P580","label":"start date","type":"wbpropconstant"},"value":{"type":"wbdatevariable","columnName":"start"}},{"prop":{"datatype":"time","pid":"P582","label":"end date","type":"wbpropconstant"},"value":{"type":"wbdatevariable","columnName":"end"}}],"value":{"label":"president","type":"wbitemconstant","qid":"Q30461"}}]}],"nameDescs":[]},{"subject":{"label":"History of Medicine Society","type":"wbitemconstant","qid":"Q37461404"},"statementGroups":[{"property":{"datatype":"wikibase-item","pid":"P488","label":"chairperson","type":"wbpropconstant"},"statements":[{"references":[{"snaks":[{"prop":{"datatype":"wikibase-item","pid":"P248","label":"stated in","type":"wbpropconstant"},"value":{"label":"The History of The Royal Society of Medicine","type":"wbitemconstant","qid":"Q42036099"}},{"prop":{"datatype":"string","pid":"P304","label":"page","type":"wbpropconstant"},"value":{"type":"wbstringconstant","value":"330-333"}}]}],"qualifiers":[{"prop":{"datatype":"time","pid":"P580","label":"start date","type":"wbpropconstant"},"value":{"type":"wbdatevariable","columnName":"start"}},{"prop":{"datatype":"time","pid":"P582","label":"end date","type":"wbpropconstant"},"value":{"type":"wbdatevariable","columnName":"end"}}],"value":{"type":"wbitemvariable","columnName":"name"}}]}],"nameDescs":[]}],"siteIri":"http://www.wikidata.org/entity/","mediaWikiApiEndpoint":"https://www.wikidata.org/w/api.php","entityTypeSiteIRI":{}}
|
||||
|
@ -21,6 +21,7 @@
|
||||
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||
* SOFTWARE.
|
||||
******************************************************************************/
|
||||
|
||||
package org.openrefine.wikidata.commands;
|
||||
|
||||
import static org.mockito.Mockito.mock;
|
||||
@ -50,7 +51,6 @@ public abstract class CommandTest extends WikidataRefineTest {
|
||||
|
||||
protected Command command = null;
|
||||
|
||||
|
||||
@BeforeMethod(alwaysRun = true)
|
||||
public void setUpProject() {
|
||||
project = createCSVProject(TestingData.inceptionWithNewCsv);
|
||||
|
@ -0,0 +1,63 @@
|
||||
|
||||
package org.openrefine.wikidata.commands;
|
||||
|
||||
public class ConnectionManagerTests {
|
||||
/**
|
||||
*
|
||||
* TODO the following tests were written for LoginCommand but actually test ConnectionManager. They should be
|
||||
* rewritten to directly test this class.
|
||||
*
|
||||
*
|
||||
* @Test public void testLogoutFailedBecauseCredentialsExpired() throws Exception { // if our credentials expire and
|
||||
* we try to log out, // we should consider that the logout succeeded. // Workaround for
|
||||
* https://github.com/Wikidata/Wikidata-Toolkit/issues/511 BasicApiConnection connection =
|
||||
* mock(BasicApiConnection.class);
|
||||
* whenNew(BasicApiConnection.class).withAnyArguments().thenReturn(connection);
|
||||
* when(connection.getCurrentUser()).thenReturn(username);
|
||||
*
|
||||
* when(request.getParameter("csrf_token")).thenReturn(Command.csrfFactory.getFreshToken());
|
||||
* when(request.getParameter(API_ENDPOINT)).thenReturn(apiEndpoint);
|
||||
* when(request.getParameter(USERNAME)).thenReturn(username);
|
||||
* when(request.getParameter(PASSWORD)).thenReturn(password);
|
||||
*
|
||||
* // login first command.doPost(request, response);
|
||||
*
|
||||
* assertTrue(ConnectionManager.getInstance().isLoggedIn(apiEndpoint));
|
||||
*
|
||||
* // logout when(request.getParameter("logout")).thenReturn("true"); doThrow(new
|
||||
* MediaWikiApiErrorException("assertuserfailed", "No longer logged in")).when(connection).logout();
|
||||
* command.doPost(request, response);
|
||||
*
|
||||
* // not logged in anymore assertFalse(ConnectionManager.getInstance().isLoggedIn(apiEndpoint)); }
|
||||
*
|
||||
* @Test public void testMultipleConnections() throws Exception { BasicApiConnection connection =
|
||||
* mock(BasicApiConnection.class);
|
||||
* whenNew(BasicApiConnection.class).withAnyArguments().thenReturn(connection);
|
||||
* when(connection.getCurrentUser()).thenReturn(username);
|
||||
*
|
||||
* String wikibase1 = "https://www.wikibase1.org/w/api.php"; String wikibase2 =
|
||||
* "https://www.wikibase2.org/w/api.php";
|
||||
*
|
||||
* when(request.getParameter("csrf_token")).thenReturn(Command.csrfFactory.getFreshToken());
|
||||
* when(request.getParameter(USERNAME)).thenReturn(username);
|
||||
* when(request.getParameter(PASSWORD)).thenReturn(password);
|
||||
*
|
||||
* // login to one endpoint first when(request.getParameter(API_ENDPOINT)).thenReturn(wikibase1);
|
||||
* command.doPost(request, response);
|
||||
*
|
||||
* // not logged in to another endpoint assertFalse(ConnectionManager.getInstance().isLoggedIn(wikibase2));
|
||||
*
|
||||
* // login to another endpoint when(request.getParameter(API_ENDPOINT)).thenReturn(wikibase2);
|
||||
* command.doPost(request, response);
|
||||
*
|
||||
* // logged in to both endpoints assertTrue(ConnectionManager.getInstance().isLoggedIn(wikibase1));
|
||||
* assertTrue(ConnectionManager.getInstance().isLoggedIn(wikibase2));
|
||||
*
|
||||
* // logout from the first endpoint when(request.getParameter("logout")).thenReturn("true");
|
||||
* when(request.getParameter(API_ENDPOINT)).thenReturn(wikibase1); command.doPost(request, response);
|
||||
*
|
||||
* // logged out from the first endpoint assertFalse(ConnectionManager.getInstance().isLoggedIn(wikibase1));
|
||||
*
|
||||
* // still logged in to another endpoint assertTrue(ConnectionManager.getInstance().isLoggedIn(wikibase2)); }
|
||||
*/
|
||||
}
|
@ -1,22 +1,28 @@
|
||||
|
||||
package org.openrefine.wikidata.commands;
|
||||
|
||||
import com.google.refine.ProjectManager;
|
||||
import com.google.refine.commands.Command;
|
||||
import com.google.refine.preference.PreferenceStore;
|
||||
import com.google.refine.util.ParsingUtilities;
|
||||
import org.mockito.ArgumentCaptor;
|
||||
import org.powermock.core.classloader.annotations.PrepareForTest;
|
||||
import org.testng.annotations.BeforeClass;
|
||||
import org.testng.annotations.BeforeMethod;
|
||||
import org.testng.annotations.Test;
|
||||
import org.wikidata.wdtk.wikibaseapi.BasicApiConnection;
|
||||
import org.wikidata.wdtk.wikibaseapi.LoginFailedException;
|
||||
import org.wikidata.wdtk.wikibaseapi.OAuthApiConnection;
|
||||
import org.wikidata.wdtk.wikibaseapi.apierrors.AssertUserFailedException;
|
||||
import org.wikidata.wdtk.wikibaseapi.apierrors.MediaWikiApiErrorException;
|
||||
import static com.google.refine.util.TestUtils.assertEqualAsJson;
|
||||
import static org.mockito.ArgumentMatchers.eq;
|
||||
import static org.mockito.Mockito.times;
|
||||
import static org.mockito.Mockito.verify;
|
||||
import static org.openrefine.wikidata.commands.LoginCommand.ACCESS_SECRET;
|
||||
import static org.openrefine.wikidata.commands.LoginCommand.ACCESS_TOKEN;
|
||||
import static org.openrefine.wikidata.commands.LoginCommand.API_ENDPOINT;
|
||||
import static org.openrefine.wikidata.commands.LoginCommand.CONSUMER_SECRET;
|
||||
import static org.openrefine.wikidata.commands.LoginCommand.CONSUMER_TOKEN;
|
||||
import static org.openrefine.wikidata.commands.LoginCommand.PASSWORD;
|
||||
import static org.openrefine.wikidata.commands.LoginCommand.USERNAME;
|
||||
import static org.openrefine.wikidata.commands.LoginCommand.WIKIBASE_COOKIE_PREFIX;
|
||||
import static org.openrefine.wikidata.commands.LoginCommand.getCookieValue;
|
||||
import static org.openrefine.wikidata.commands.LoginCommand.removeCRLF;
|
||||
import static org.openrefine.wikidata.commands.LoginCommand.sanitizeCookieKey;
|
||||
import static org.mockito.Mockito.doNothing;
|
||||
import static org.mockito.Mockito.mock;
|
||||
import static org.mockito.Mockito.when;
|
||||
import static org.testng.Assert.assertEquals;
|
||||
import static org.testng.Assert.assertFalse;
|
||||
import static org.testng.Assert.assertNotEquals;
|
||||
|
||||
import javax.servlet.ServletException;
|
||||
import javax.servlet.http.Cookie;
|
||||
import java.io.IOException;
|
||||
import java.io.PrintWriter;
|
||||
import java.io.StringWriter;
|
||||
@ -28,15 +34,18 @@ import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
import static com.google.refine.util.TestUtils.assertEqualAsJson;
|
||||
import static org.mockito.ArgumentMatchers.anyMap;
|
||||
import static org.mockito.BDDMockito.given;
|
||||
import static org.mockito.Mockito.verify;
|
||||
import static org.openrefine.wikidata.commands.LoginCommand.*;
|
||||
import static org.powermock.api.mockito.PowerMockito.*;
|
||||
import static org.testng.Assert.*;
|
||||
import javax.servlet.ServletException;
|
||||
import javax.servlet.http.Cookie;
|
||||
|
||||
import org.mockito.ArgumentCaptor;
|
||||
import org.mockito.Mockito;
|
||||
import org.testng.annotations.BeforeMethod;
|
||||
import org.testng.annotations.Test;
|
||||
import org.wikidata.wdtk.wikibaseapi.BasicApiConnection;
|
||||
import org.wikidata.wdtk.wikibaseapi.OAuthApiConnection;
|
||||
|
||||
import com.google.refine.commands.Command;
|
||||
|
||||
@PrepareForTest(ConnectionManager.class)
|
||||
public class LoginCommandTest extends CommandTest {
|
||||
|
||||
private static final String apiEndpoint = "https://www.wikidata.org/w/api.php";
|
||||
@ -71,37 +80,19 @@ public class LoginCommandTest extends CommandTest {
|
||||
// used for mocking singleton
|
||||
Constructor<ConnectionManager> constructor;
|
||||
|
||||
@BeforeClass
|
||||
public void initConstructor() throws NoSuchMethodException {
|
||||
constructor = ConnectionManager.class.getDeclaredConstructor();
|
||||
constructor.setAccessible(true);
|
||||
}
|
||||
ConnectionManager connectionManager;
|
||||
|
||||
@BeforeMethod
|
||||
public void setUp() throws Exception {
|
||||
command = new LoginCommand();
|
||||
|
||||
// mock the ConnectionManager singleton
|
||||
ConnectionManager manager = constructor.newInstance();
|
||||
mockStatic(ConnectionManager.class);
|
||||
given(ConnectionManager.getInstance()).willReturn(manager);
|
||||
connectionManager = mock(ConnectionManager.class);
|
||||
((LoginCommand) command).setConnectionManager(connectionManager);
|
||||
|
||||
when(request.getCookies()).thenReturn(new Cookie[] {});
|
||||
cookieCaptor = ArgumentCaptor.forClass(Cookie.class);
|
||||
doNothing().when(response).addCookie(cookieCaptor.capture());
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testClearCredentialsInPreferences() throws Exception {
|
||||
PreferenceStore prefStore = new PreferenceStore();
|
||||
ProjectManager.singleton = mock(ProjectManager.class);
|
||||
when(ProjectManager.singleton.getPreferenceStore()).thenReturn(prefStore);
|
||||
prefStore.put(ConnectionManager.PREFERENCE_STORE_KEY, ParsingUtilities.mapper.createArrayNode());
|
||||
assertNotNull(prefStore.get(ConnectionManager.PREFERENCE_STORE_KEY));
|
||||
constructor.newInstance();
|
||||
assertNull(prefStore.get(ConnectionManager.PREFERENCE_STORE_KEY));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testNoApiEndpointPost() throws ServletException, IOException {
|
||||
when(request.getParameter("csrf_token")).thenReturn(Command.csrfFactory.getFreshToken());
|
||||
@ -137,26 +128,24 @@ public class LoginCommandTest extends CommandTest {
|
||||
}
|
||||
|
||||
private void assertLogin() {
|
||||
assertTrue(ConnectionManager.getInstance().isLoggedIn(apiEndpoint));
|
||||
assertEqualAsJson("{\"logged_in\":true,\"username\":\"" + username + "\",\"mediawiki_api_endpoint\":\"" + apiEndpoint + "\"}",
|
||||
writer.toString());
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testUsernamePasswordLogin() throws Exception {
|
||||
BasicApiConnection connection = mock(BasicApiConnection.class);
|
||||
whenNew(BasicApiConnection.class).withAnyArguments().thenReturn(connection);
|
||||
when(connection.getCurrentUser()).thenReturn(username);
|
||||
when(connection.getCookies()).thenReturn(makeResponseCookies());
|
||||
|
||||
when(request.getParameter("csrf_token")).thenReturn(Command.csrfFactory.getFreshToken());
|
||||
when(request.getParameter(API_ENDPOINT)).thenReturn(apiEndpoint);
|
||||
when(request.getParameter(USERNAME)).thenReturn(username);
|
||||
when(request.getParameter(PASSWORD)).thenReturn(password);
|
||||
|
||||
when(connectionManager.login(apiEndpoint, username, password)).thenReturn(true);
|
||||
when(connectionManager.isLoggedIn(apiEndpoint)).thenReturn(true);
|
||||
when(connectionManager.getUsername(apiEndpoint)).thenReturn(username);
|
||||
|
||||
command.doPost(request, response);
|
||||
|
||||
verify(connection).login(username, password);
|
||||
verify(connectionManager, times(1)).login(apiEndpoint, username, password);
|
||||
|
||||
assertLogin();
|
||||
|
||||
@ -171,24 +160,29 @@ public class LoginCommandTest extends CommandTest {
|
||||
|
||||
@Test
|
||||
public void testUsernamePasswordLoginRememberCredentials() throws Exception {
|
||||
BasicApiConnection connection = mock(BasicApiConnection.class);
|
||||
whenNew(BasicApiConnection.class).withAnyArguments().thenReturn(connection);
|
||||
when(connection.getCurrentUser()).thenReturn(username);
|
||||
when(connection.getCookies()).thenReturn(makeResponseCookies());
|
||||
|
||||
when(request.getParameter("csrf_token")).thenReturn(Command.csrfFactory.getFreshToken());
|
||||
when(request.getParameter("remember-credentials")).thenReturn("on");
|
||||
when(request.getParameter(API_ENDPOINT)).thenReturn(apiEndpoint);
|
||||
when(request.getParameter(USERNAME)).thenReturn(username);
|
||||
when(request.getParameter(PASSWORD)).thenReturn(password);
|
||||
|
||||
when(connectionManager.login(apiEndpoint, username, password)).thenReturn(true);
|
||||
when(connectionManager.isLoggedIn(apiEndpoint)).thenReturn(true);
|
||||
when(connectionManager.getUsername(apiEndpoint)).thenReturn(username);
|
||||
BasicApiConnection connection = mock(BasicApiConnection.class);
|
||||
when(connectionManager.getConnection(apiEndpoint)).thenReturn(connection);
|
||||
when(connection.getCookies()).thenReturn(makeResponseCookies());
|
||||
when(connection.getCurrentUser()).thenReturn(username);
|
||||
|
||||
command.doPost(request, response);
|
||||
|
||||
verify(connection).login(username, password);
|
||||
verify(connectionManager, times(1)).login(apiEndpoint, username, password);
|
||||
|
||||
assertLogin();
|
||||
|
||||
Map<String, Cookie> cookies = getCookieMap(cookieCaptor.getAllValues());
|
||||
cookieMap.forEach((key, value) -> assertCookieEquals(cookies.get(apiEndpointPrefix + WIKIBASE_COOKIE_PREFIX + key), value, ONE_YEAR));
|
||||
cookieMap.forEach(
|
||||
(key, value) -> assertCookieEquals(cookies.get(apiEndpointPrefix + WIKIBASE_COOKIE_PREFIX + key), value, ONE_YEAR));
|
||||
assertCookieEquals(cookies.get(apiEndpointPrefix + USERNAME), username, ONE_YEAR);
|
||||
assertCookieEquals(cookies.get(apiEndpointPrefix + CONSUMER_TOKEN), "", 0);
|
||||
assertCookieEquals(cookies.get(apiEndpointPrefix + CONSUMER_SECRET), "", 0);
|
||||
@ -198,18 +192,22 @@ public class LoginCommandTest extends CommandTest {
|
||||
|
||||
@Test
|
||||
public void testUsernamePasswordLoginWithCookies() throws Exception {
|
||||
BasicApiConnection connection = mock(BasicApiConnection.class);
|
||||
given(ConnectionManager.convertToBasicApiConnection(anyMap())).willReturn(connection);
|
||||
when(connection.getCurrentUser()).thenReturn(username);
|
||||
when(connection.getCookies()).thenReturn(makeResponseCookies());
|
||||
|
||||
when(request.getParameter("csrf_token")).thenReturn(Command.csrfFactory.getFreshToken());
|
||||
when(request.getParameter(API_ENDPOINT)).thenReturn(apiEndpoint);
|
||||
when(request.getCookies()).thenReturn(makeRequestCookies());
|
||||
|
||||
when(connectionManager.login(eq(apiEndpoint), eq(username), Mockito.<List<Cookie>> any())).thenReturn(true);
|
||||
when(connectionManager.isLoggedIn(apiEndpoint)).thenReturn(true);
|
||||
when(connectionManager.getUsername(apiEndpoint)).thenReturn(username);
|
||||
BasicApiConnection connection = mock(BasicApiConnection.class);
|
||||
when(connectionManager.getConnection(apiEndpoint)).thenReturn(connection);
|
||||
when(connection.getCookies()).thenReturn(makeResponseCookies());
|
||||
when(connection.getCurrentUser()).thenReturn(username);
|
||||
|
||||
command.doPost(request, response);
|
||||
|
||||
verify(connection).checkCredentials();
|
||||
verify(connectionManager, times(1)).login(eq(apiEndpoint), eq(username), Mockito.<List<Cookie>> any());
|
||||
|
||||
assertLogin();
|
||||
|
||||
Map<String, Cookie> cookies = getCookieMap(cookieCaptor.getAllValues());
|
||||
@ -222,10 +220,6 @@ public class LoginCommandTest extends CommandTest {
|
||||
|
||||
@Test
|
||||
public void testOwnerOnlyConsumerLogin() throws Exception {
|
||||
OAuthApiConnection connection = mock(OAuthApiConnection.class);
|
||||
whenNew(OAuthApiConnection.class).withAnyArguments().thenReturn(connection);
|
||||
when(connection.getCurrentUser()).thenReturn(username);
|
||||
|
||||
when(request.getParameter("csrf_token")).thenReturn(Command.csrfFactory.getFreshToken());
|
||||
when(request.getParameter(API_ENDPOINT)).thenReturn(apiEndpoint);
|
||||
when(request.getParameter(CONSUMER_TOKEN)).thenReturn(consumerToken);
|
||||
@ -233,8 +227,17 @@ public class LoginCommandTest extends CommandTest {
|
||||
when(request.getParameter(ACCESS_TOKEN)).thenReturn(accessToken);
|
||||
when(request.getParameter(ACCESS_SECRET)).thenReturn(accessSecret);
|
||||
|
||||
when(connectionManager.login(apiEndpoint, consumerToken, consumerSecret, accessToken, accessSecret)).thenReturn(true);
|
||||
when(connectionManager.isLoggedIn(apiEndpoint)).thenReturn(true);
|
||||
when(connectionManager.getUsername(apiEndpoint)).thenReturn(username);
|
||||
OAuthApiConnection connection = mock(OAuthApiConnection.class);
|
||||
when(connectionManager.getConnection(apiEndpoint)).thenReturn(connection);
|
||||
when(connection.getCurrentUser()).thenReturn(username);
|
||||
|
||||
command.doPost(request, response);
|
||||
|
||||
verify(connectionManager, times(1)).login(apiEndpoint, consumerToken, consumerSecret, accessToken, accessSecret);
|
||||
|
||||
assertLogin();
|
||||
|
||||
Map<String, Cookie> cookies = getCookieMap(cookieCaptor.getAllValues());
|
||||
@ -248,10 +251,6 @@ public class LoginCommandTest extends CommandTest {
|
||||
|
||||
@Test
|
||||
public void testOwnerOnlyConsumerLoginRememberCredentials() throws Exception {
|
||||
OAuthApiConnection connection = mock(OAuthApiConnection.class);
|
||||
whenNew(OAuthApiConnection.class).withAnyArguments().thenReturn(connection);
|
||||
when(connection.getCurrentUser()).thenReturn(username);
|
||||
|
||||
when(request.getParameter("csrf_token")).thenReturn(Command.csrfFactory.getFreshToken());
|
||||
when(request.getParameter("remember-credentials")).thenReturn("on");
|
||||
when(request.getParameter(API_ENDPOINT)).thenReturn(apiEndpoint);
|
||||
@ -261,8 +260,16 @@ public class LoginCommandTest extends CommandTest {
|
||||
when(request.getParameter(ACCESS_SECRET)).thenReturn(accessSecret);
|
||||
when(request.getCookies()).thenReturn(makeRequestCookies());
|
||||
|
||||
when(connectionManager.login(apiEndpoint, consumerToken, consumerSecret, accessToken, accessSecret)).thenReturn(true);
|
||||
when(connectionManager.isLoggedIn(apiEndpoint)).thenReturn(true);
|
||||
when(connectionManager.getUsername(apiEndpoint)).thenReturn(username);
|
||||
OAuthApiConnection connection = mock(OAuthApiConnection.class);
|
||||
when(connectionManager.getConnection(apiEndpoint)).thenReturn(connection);
|
||||
when(connection.getCurrentUser()).thenReturn(username);
|
||||
|
||||
command.doPost(request, response);
|
||||
|
||||
verify(connectionManager, times(1)).login(apiEndpoint, consumerToken, consumerSecret, accessToken, accessSecret);
|
||||
assertLogin();
|
||||
|
||||
Map<String, Cookie> cookies = getCookieMap(cookieCaptor.getAllValues());
|
||||
@ -278,19 +285,26 @@ public class LoginCommandTest extends CommandTest {
|
||||
|
||||
@Test
|
||||
public void testOwnerOnlyConsumerLoginWithCookies() throws Exception {
|
||||
OAuthApiConnection connection = mock(OAuthApiConnection.class);
|
||||
whenNew(OAuthApiConnection.class).withAnyArguments().thenReturn(connection);
|
||||
when(connection.getCurrentUser()).thenReturn(username);
|
||||
|
||||
when(request.getParameter("csrf_token")).thenReturn(Command.csrfFactory.getFreshToken());
|
||||
when(request.getParameter(API_ENDPOINT)).thenReturn(apiEndpoint);
|
||||
Cookie consumerTokenCookie = new Cookie(apiEndpointPrefix + CONSUMER_TOKEN, consumerToken);
|
||||
Cookie consumerSecretCookie = new Cookie(apiEndpointPrefix + CONSUMER_SECRET, consumerSecret);
|
||||
Cookie accessTokenCookie = new Cookie(apiEndpointPrefix + ACCESS_TOKEN, accessToken);
|
||||
Cookie accessSecretCookie = new Cookie(apiEndpointPrefix + ACCESS_SECRET, accessSecret);
|
||||
when(request.getCookies()).thenReturn(new Cookie[]{consumerTokenCookie, consumerSecretCookie, accessTokenCookie, accessSecretCookie});
|
||||
when(request.getCookies())
|
||||
.thenReturn(new Cookie[] { consumerTokenCookie, consumerSecretCookie, accessTokenCookie, accessSecretCookie });
|
||||
|
||||
when(connectionManager.login(apiEndpoint, consumerToken, consumerSecret, accessToken, accessSecret)).thenReturn(true);
|
||||
when(connectionManager.isLoggedIn(apiEndpoint)).thenReturn(true);
|
||||
when(connectionManager.getUsername(apiEndpoint)).thenReturn(username);
|
||||
OAuthApiConnection connection = mock(OAuthApiConnection.class);
|
||||
when(connectionManager.getConnection(apiEndpoint)).thenReturn(connection);
|
||||
when(connection.getCurrentUser()).thenReturn(username);
|
||||
|
||||
command.doPost(request, response);
|
||||
|
||||
verify(connectionManager, times(1)).login(apiEndpoint, consumerToken, consumerSecret, accessToken, accessSecret);
|
||||
|
||||
assertLogin();
|
||||
|
||||
Map<String, Cookie> cookies = getCookieMap(cookieCaptor.getAllValues());
|
||||
@ -304,9 +318,6 @@ public class LoginCommandTest extends CommandTest {
|
||||
|
||||
@Test
|
||||
public void testCookieEncoding() throws Exception {
|
||||
OAuthApiConnection connection = mock(OAuthApiConnection.class);
|
||||
whenNew(OAuthApiConnection.class).withAnyArguments().thenReturn(connection);
|
||||
|
||||
when(request.getParameter("csrf_token")).thenReturn(Command.csrfFactory.getFreshToken());
|
||||
when(request.getParameter("remember-credentials")).thenReturn("on");
|
||||
when(request.getParameter(API_ENDPOINT)).thenReturn(apiEndpoint);
|
||||
@ -316,6 +327,14 @@ public class LoginCommandTest extends CommandTest {
|
||||
when(request.getParameter(ACCESS_SECRET)).thenReturn(accessSecret);
|
||||
when(request.getCookies()).thenReturn(makeRequestCookies());
|
||||
|
||||
when(connectionManager.login(apiEndpoint, "malformed consumer token \r\n %?", consumerSecret, accessToken, accessSecret))
|
||||
.thenReturn(true);
|
||||
when(connectionManager.isLoggedIn(apiEndpoint)).thenReturn(true);
|
||||
when(connectionManager.getUsername(apiEndpoint)).thenReturn(username);
|
||||
OAuthApiConnection connection = mock(OAuthApiConnection.class);
|
||||
when(connectionManager.getConnection(apiEndpoint)).thenReturn(connection);
|
||||
when(connection.getCurrentUser()).thenReturn(username);
|
||||
|
||||
command.doPost(request, response);
|
||||
|
||||
Map<String, Cookie> cookies = getCookieMap(cookieCaptor.getAllValues());
|
||||
@ -325,43 +344,47 @@ public class LoginCommandTest extends CommandTest {
|
||||
|
||||
@Test
|
||||
public void testCookieDecoding() throws Exception {
|
||||
ConnectionManager manager = mock(ConnectionManager.class);
|
||||
given(ConnectionManager.getInstance()).willReturn(manager);
|
||||
|
||||
OAuthApiConnection connection = mock(OAuthApiConnection.class);
|
||||
whenNew(OAuthApiConnection.class).withAnyArguments().thenReturn(connection);
|
||||
when(connection.getCurrentUser()).thenReturn(username);
|
||||
|
||||
when(request.getParameter("csrf_token")).thenReturn(Command.csrfFactory.getFreshToken());
|
||||
when(request.getParameter(API_ENDPOINT)).thenReturn(apiEndpoint);
|
||||
Cookie consumerTokenCookie = new Cookie(apiEndpointPrefix + CONSUMER_TOKEN, "malformed+consumer+token+%0D%0A+%25%3F");
|
||||
Cookie consumerSecretCookie = new Cookie(apiEndpointPrefix + CONSUMER_SECRET, consumerSecret);
|
||||
Cookie accessTokenCookie = new Cookie(apiEndpointPrefix + ACCESS_TOKEN, accessToken);
|
||||
Cookie accessSecretCookie = new Cookie(apiEndpointPrefix + ACCESS_SECRET, accessSecret);
|
||||
when(request.getCookies()).thenReturn(new Cookie[]{consumerTokenCookie, consumerSecretCookie, accessTokenCookie, accessSecretCookie});
|
||||
when(request.getCookies())
|
||||
.thenReturn(new Cookie[] { consumerTokenCookie, consumerSecretCookie, accessTokenCookie, accessSecretCookie });
|
||||
|
||||
when(connectionManager.login(apiEndpoint, "malformed consumer token \r\n %?", consumerSecret, accessToken, accessSecret))
|
||||
.thenReturn(true);
|
||||
when(connectionManager.isLoggedIn(apiEndpoint)).thenReturn(true);
|
||||
when(connectionManager.getUsername(apiEndpoint)).thenReturn(username);
|
||||
OAuthApiConnection connection = mock(OAuthApiConnection.class);
|
||||
when(connectionManager.getConnection(apiEndpoint)).thenReturn(connection);
|
||||
when(connection.getCurrentUser()).thenReturn(username);
|
||||
|
||||
command.doPost(request, response);
|
||||
|
||||
verify(manager).login(apiEndpoint, "malformed consumer token \r\n %?", consumerSecret, accessToken, accessSecret);
|
||||
verify(connectionManager).login(apiEndpoint, "malformed consumer token \r\n %?", consumerSecret, accessToken, accessSecret);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testLogout() throws Exception {
|
||||
BasicApiConnection connection = mock(BasicApiConnection.class);
|
||||
whenNew(BasicApiConnection.class).withAnyArguments().thenReturn(connection);
|
||||
when(connection.getCurrentUser()).thenReturn(username);
|
||||
when(connection.getCookies()).thenReturn(makeResponseCookies());
|
||||
|
||||
when(request.getParameter("csrf_token")).thenReturn(Command.csrfFactory.getFreshToken());
|
||||
when(request.getParameter(API_ENDPOINT)).thenReturn(apiEndpoint);
|
||||
when(request.getParameter(USERNAME)).thenReturn(username);
|
||||
when(request.getParameter(PASSWORD)).thenReturn(password);
|
||||
|
||||
when(connectionManager.login(apiEndpoint, username, password)).thenReturn(true);
|
||||
when(connectionManager.isLoggedIn(apiEndpoint)).thenReturn(true);
|
||||
when(connectionManager.getUsername(apiEndpoint)).thenReturn(username);
|
||||
|
||||
// login first
|
||||
command.doPost(request, response);
|
||||
|
||||
int loginCookiesSize = cookieCaptor.getAllValues().size();
|
||||
|
||||
verify(connectionManager, times(1)).login(apiEndpoint, username, password);
|
||||
|
||||
assertLogin();
|
||||
|
||||
// logout
|
||||
@ -370,12 +393,18 @@ public class LoginCommandTest extends CommandTest {
|
||||
StringWriter logoutWriter = new StringWriter();
|
||||
when(response.getWriter()).thenReturn(new PrintWriter(logoutWriter));
|
||||
|
||||
when(connectionManager.isLoggedIn(apiEndpoint)).thenReturn(false);
|
||||
when(connectionManager.getUsername(apiEndpoint)).thenReturn(null);
|
||||
|
||||
command.doPost(request, response);
|
||||
|
||||
assertFalse(ConnectionManager.getInstance().isLoggedIn(apiEndpoint));
|
||||
assertEqualAsJson("{\"logged_in\":false,\"username\":null, \"mediawiki_api_endpoint\":\"" + apiEndpoint + "\"}", logoutWriter.toString());
|
||||
verify(connectionManager).logout(apiEndpoint);
|
||||
when(connectionManager.isLoggedIn(apiEndpoint)).thenReturn(false);
|
||||
assertEqualAsJson("{\"logged_in\":false,\"username\":null, \"mediawiki_api_endpoint\":\"" + apiEndpoint + "\"}",
|
||||
logoutWriter.toString());
|
||||
|
||||
Map<String, Cookie> cookies = getCookieMap(cookieCaptor.getAllValues().subList(loginCookiesSize, cookieCaptor.getAllValues().size()));
|
||||
Map<String, Cookie> cookies = getCookieMap(
|
||||
cookieCaptor.getAllValues().subList(loginCookiesSize, cookieCaptor.getAllValues().size()));
|
||||
cookieMap.forEach((key, value) -> assertCookieEquals(cookies.get(apiEndpointPrefix + WIKIBASE_COOKIE_PREFIX + key), "", 0));
|
||||
assertCookieEquals(cookies.get(apiEndpointPrefix + USERNAME), "", 0);
|
||||
assertCookieEquals(cookies.get(apiEndpointPrefix + CONSUMER_TOKEN), "", 0);
|
||||
@ -386,46 +415,43 @@ public class LoginCommandTest extends CommandTest {
|
||||
|
||||
@Test
|
||||
public void testUsernamePasswordLoginFailed() throws Exception {
|
||||
BasicApiConnection connection = mock(BasicApiConnection.class);
|
||||
whenNew(BasicApiConnection.class).withAnyArguments().thenReturn(connection);
|
||||
doThrow(new LoginFailedException("login failed")).when(connection).login(username, password);
|
||||
|
||||
when(request.getParameter("csrf_token")).thenReturn(Command.csrfFactory.getFreshToken());
|
||||
when(request.getParameter(API_ENDPOINT)).thenReturn(apiEndpoint);
|
||||
// we don't check the username/password here
|
||||
when(request.getParameter(USERNAME)).thenReturn(username);
|
||||
when(request.getParameter(PASSWORD)).thenReturn(password);
|
||||
|
||||
when(connectionManager.login(apiEndpoint, username, password)).thenReturn(false);
|
||||
when(connectionManager.isLoggedIn(apiEndpoint)).thenReturn(false);
|
||||
when(connectionManager.getUsername(apiEndpoint)).thenReturn(null);
|
||||
|
||||
// login first
|
||||
command.doPost(request, response);
|
||||
|
||||
verify(connection).login(username, password);
|
||||
assertFalse(ConnectionManager.getInstance().isLoggedIn(apiEndpoint));
|
||||
verify(connectionManager).login(apiEndpoint, username, password);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testUsernamePasswordWithCookiesLoginFailed() throws Exception {
|
||||
BasicApiConnection connection = mock(BasicApiConnection.class);
|
||||
given(ConnectionManager.convertToBasicApiConnection(anyMap())).willReturn(connection);
|
||||
doThrow(new AssertUserFailedException("assert user login failed")).when(connection).checkCredentials();
|
||||
|
||||
when(request.getParameter("csrf_token")).thenReturn(Command.csrfFactory.getFreshToken());
|
||||
when(request.getParameter(API_ENDPOINT)).thenReturn(apiEndpoint);
|
||||
// we don't check the username/password here
|
||||
when(request.getCookies()).thenReturn(makeRequestCookies());
|
||||
|
||||
when(connectionManager.login(eq(apiEndpoint), eq(username), Mockito.<List<Cookie>> any())).thenReturn(false);
|
||||
when(connectionManager.isLoggedIn(apiEndpoint)).thenReturn(false);
|
||||
when(connectionManager.getUsername(apiEndpoint)).thenReturn(null);
|
||||
when(connectionManager.getConnection(apiEndpoint)).thenReturn(null);
|
||||
|
||||
// login first
|
||||
command.doPost(request, response);
|
||||
|
||||
verify(connection).checkCredentials();
|
||||
verify(connectionManager).login(eq(apiEndpoint), eq(username), Mockito.<List<Cookie>> any());
|
||||
assertFalse(ConnectionManager.getInstance().isLoggedIn(apiEndpoint));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testOwnerOnlyConsumerLoginFailed() throws Exception {
|
||||
OAuthApiConnection connection = mock(OAuthApiConnection.class);
|
||||
whenNew(OAuthApiConnection.class).withAnyArguments().thenReturn(connection);
|
||||
doThrow(new AssertUserFailedException("assert user login failed")).when(connection).checkCredentials();
|
||||
|
||||
when(request.getParameter("csrf_token")).thenReturn(Command.csrfFactory.getFreshToken());
|
||||
when(request.getParameter(API_ENDPOINT)).thenReturn(apiEndpoint);
|
||||
@ -434,103 +460,40 @@ public class LoginCommandTest extends CommandTest {
|
||||
when(request.getParameter(ACCESS_TOKEN)).thenReturn(accessToken);
|
||||
when(request.getParameter(ACCESS_SECRET)).thenReturn(accessSecret);
|
||||
|
||||
when(connectionManager.login(apiEndpoint, consumerToken, consumerSecret, accessToken, accessSecret)).thenReturn(false);
|
||||
when(connectionManager.isLoggedIn(apiEndpoint)).thenReturn(false);
|
||||
when(connectionManager.getUsername(apiEndpoint)).thenReturn(null);
|
||||
when(connectionManager.getConnection(apiEndpoint)).thenReturn(null);
|
||||
|
||||
command.doPost(request, response);
|
||||
|
||||
verify(connection).checkCredentials();
|
||||
assertFalse(connection.isLoggedIn());
|
||||
verify(connectionManager).login(apiEndpoint, consumerToken, consumerSecret, accessToken, accessSecret);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testLogoutFailed() throws Exception {
|
||||
BasicApiConnection connection = mock(BasicApiConnection.class);
|
||||
whenNew(BasicApiConnection.class).withAnyArguments().thenReturn(connection);
|
||||
when(connection.getCurrentUser()).thenReturn(username);
|
||||
|
||||
when(request.getParameter("csrf_token")).thenReturn(Command.csrfFactory.getFreshToken());
|
||||
when(request.getParameter(API_ENDPOINT)).thenReturn(apiEndpoint);
|
||||
when(request.getParameter(USERNAME)).thenReturn(username);
|
||||
when(request.getParameter(PASSWORD)).thenReturn(password);
|
||||
|
||||
when(connectionManager.login(apiEndpoint, username, password)).thenReturn(true);
|
||||
when(connectionManager.isLoggedIn(apiEndpoint)).thenReturn(true);
|
||||
when(connectionManager.getUsername(apiEndpoint)).thenReturn(username);
|
||||
|
||||
// login first
|
||||
command.doPost(request, response);
|
||||
|
||||
assertTrue(ConnectionManager.getInstance().isLoggedIn(apiEndpoint));
|
||||
verify(connectionManager).login(apiEndpoint, username, password);
|
||||
|
||||
// logout
|
||||
when(request.getParameter("logout")).thenReturn("true");
|
||||
doThrow(new MediaWikiApiErrorException("", "")).when(connection).logout();
|
||||
|
||||
command.doPost(request, response);
|
||||
|
||||
// still logged in
|
||||
assertTrue(ConnectionManager.getInstance().isLoggedIn(apiEndpoint));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testLogoutFailedBecauseCredentialsExpired() throws Exception {
|
||||
// if our credentials expire and we try to log out,
|
||||
// we should consider that the logout succeeded.
|
||||
// Workaround for https://github.com/Wikidata/Wikidata-Toolkit/issues/511
|
||||
BasicApiConnection connection = mock(BasicApiConnection.class);
|
||||
whenNew(BasicApiConnection.class).withAnyArguments().thenReturn(connection);
|
||||
when(connection.getCurrentUser()).thenReturn(username);
|
||||
|
||||
when(request.getParameter("csrf_token")).thenReturn(Command.csrfFactory.getFreshToken());
|
||||
when(request.getParameter(API_ENDPOINT)).thenReturn(apiEndpoint);
|
||||
when(request.getParameter(USERNAME)).thenReturn(username);
|
||||
when(request.getParameter(PASSWORD)).thenReturn(password);
|
||||
|
||||
// login first
|
||||
command.doPost(request, response);
|
||||
|
||||
assertTrue(ConnectionManager.getInstance().isLoggedIn(apiEndpoint));
|
||||
|
||||
// logout
|
||||
when(request.getParameter("logout")).thenReturn("true");
|
||||
doThrow(new MediaWikiApiErrorException("assertuserfailed", "No longer logged in")).when(connection).logout();
|
||||
command.doPost(request, response);
|
||||
|
||||
// not logged in anymore
|
||||
assertFalse(ConnectionManager.getInstance().isLoggedIn(apiEndpoint));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testMultipleConnections() throws Exception {
|
||||
BasicApiConnection connection = mock(BasicApiConnection.class);
|
||||
whenNew(BasicApiConnection.class).withAnyArguments().thenReturn(connection);
|
||||
when(connection.getCurrentUser()).thenReturn(username);
|
||||
|
||||
String wikibase1 = "https://www.wikibase1.org/w/api.php";
|
||||
String wikibase2 = "https://www.wikibase2.org/w/api.php";
|
||||
|
||||
when(request.getParameter("csrf_token")).thenReturn(Command.csrfFactory.getFreshToken());
|
||||
when(request.getParameter(USERNAME)).thenReturn(username);
|
||||
when(request.getParameter(PASSWORD)).thenReturn(password);
|
||||
|
||||
// login to one endpoint first
|
||||
when(request.getParameter(API_ENDPOINT)).thenReturn(wikibase1);
|
||||
command.doPost(request, response);
|
||||
|
||||
// not logged in to another endpoint
|
||||
assertFalse(ConnectionManager.getInstance().isLoggedIn(wikibase2));
|
||||
|
||||
// login to another endpoint
|
||||
when(request.getParameter(API_ENDPOINT)).thenReturn(wikibase2);
|
||||
command.doPost(request, response);
|
||||
|
||||
// logged in to both endpoints
|
||||
assertTrue(ConnectionManager.getInstance().isLoggedIn(wikibase1));
|
||||
assertTrue(ConnectionManager.getInstance().isLoggedIn(wikibase2));
|
||||
|
||||
// logout from the first endpoint
|
||||
when(request.getParameter("logout")).thenReturn("true");
|
||||
when(request.getParameter(API_ENDPOINT)).thenReturn(wikibase1);
|
||||
command.doPost(request, response);
|
||||
|
||||
// logged out from the first endpoint
|
||||
assertFalse(ConnectionManager.getInstance().isLoggedIn(wikibase1));
|
||||
|
||||
// still logged in to another endpoint
|
||||
assertTrue(ConnectionManager.getInstance().isLoggedIn(wikibase2));
|
||||
verify(connectionManager).logout(apiEndpoint);
|
||||
assertLogin();
|
||||
}
|
||||
|
||||
private static Cookie[] makeRequestCookies() {
|
||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user