Compare commits

..

No commits in common. "add-documentation" and "main" have entirely different histories.

6 changed files with 22 additions and 66 deletions

5
.gitignore vendored
View file

@ -2,8 +2,3 @@ venv
__pycache__
.mypy_cache/
config/default.py
node_modules/
.vscode/
config.default
package-lock.json
config/

View file

@ -1,35 +0,0 @@
# OWL-MAP
## Setup
* clone the project
* install geoip and postgis from your local package manager
* `$ sudo pacman -S postgis geoip`
* setup postgres on your machine, see e.g. https://wiki.archlinux.org/title/PostgreSQL
* `$ sudo su postgres`
* `$ initdb -D /var/lib/postgres/data`
* start postgres
* create postgres user
* `$ sudo su postgres`
* `$ createuser --interactive` -> "owl" role with relevant priviledges
* create postgres database "matcher" with hstore and postgis extensions
* `$ psql -U postgres`
* `> CREATE DATABASE matcher;`
* `> ALTER DATABASE matcher OWNER TO owl;`
* `> CREATE EXTENSION hstore;`
* `> CREATE EXTENSION postgis;`
* create the db tables
* setup database credentials and name in default.py
* `$ python create_db.py`
* setup a venv
* enter the venv, e.g. in pycharm
* `$ pip install -r requirements.txt`
* `$ cp config/example.py config/default.py`
* download id-tagging-schema
* `$ git clone https://github.com/openstreetmap/id-tagging-schema`
* adjust paths in default.py
* download geoip databases
* https://git.io/GeoLite2-City.mmdb
* `$ pacman -S geoip-database-extra` in ArchLinux or https://dl.miyuru.lk/geoip/maxmind/city/maxmind4.dat.gz
* adjust default.py
* run the tests
* run 'python web_view.py'

View file

@ -1,8 +1,5 @@
"""Sample config."""
# POSTGIS
DB_USER = "owl"
DB_NAME = "matcher"
ID_TAGGING_SCHEMA_DIR = "/var/lib/data/id-tagging-schema"
ID_PRESET_DIR = "/var/lib/data/id-tagging-schema/data/presets/"

View file

@ -2,10 +2,9 @@
from sqlalchemy.schema import CreateIndex, CreateTable
from config.default import DB_USER, DB_NAME
from matcher import database, model
DB_URL = f"postgresql://{DB_USER}@localhost/{DB_NAME}"
DB_URL = "postgresql:///matcher"
database.init_db(DB_URL)

View file

@ -11,4 +11,3 @@ simplejson
user_agents
num2words
psycopg2
pytest===8.3.2

View file

@ -1,16 +1,15 @@
"""Test matcher utils."""
from unittest import TestCase
from matcher import utils
class TestUtils(TestCase):
def test_format_wikibase_time_year(self) -> None:
def test_format_wikibase_time_year() -> None:
"""Test passing a year to format_wikibase_time."""
v = {"time": "+1950-00-00T00:00:00Z", "precision": 9}
assert utils.format_wikibase_time(v) == "1950"
def test_format_wikibase_time_century(self) -> None:
def test_format_wikibase_time_century() -> None:
"""Test passing centuries to format_wikibase_time."""
v = {"time": "+0800-00-00T00:00:00Z", "precision": 7}
assert utils.format_wikibase_time(v) == "8th century"
@ -18,12 +17,14 @@ class TestUtils(TestCase):
v = {"time": "+1950-00-00T00:00:00Z", "precision": 7}
assert utils.format_wikibase_time(v) == "20th century"
def test_format_wikibase_time_decade(self) -> None:
def test_format_wikibase_time_decade() -> None:
"""Test passing a full date to format_wikibase_time."""
v = {"time": "+1910-00-00T00:00:00Z", "precision": 8}
assert utils.format_wikibase_time(v) == "1910s"
def test_format_wikibase_time_day(self) -> None:
def test_format_wikibase_time_day() -> None:
"""Test passing a full date to format_wikibase_time."""
v = {"time": "+1868-01-09T00:00:00Z", "precision": 11}
assert utils.format_wikibase_time(v) == "9 January 1868"