-
Notifications
You must be signed in to change notification settings - Fork 24
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Draft-3 Freifunk JSON Schema, zwar valide, aber problematisch #152
Comments
…pty schema"), draft-07 will follow
Das Build-Script (Python) im Freifunk API Directory github repo scheint besser als der API Generator zu validieren: Validation errors (summary): Wenn man z.B. die aktuelle API Datei von Bad Pymon:
im Freifunk API Generator validiert, dann findet dieser alles okay, was falsch ist. Das Python script hat jedoch recht, diese Datei ist nicht ok. Es sieht so aus als ob der Freifunk API Generator hier gegen ein "empty schema" validiert - vermutlich also das Feld "schema" nicht extrahiert (ich habe diese Vermutung nicht im Quellcode des API Generators überprüft). @andibraeu kannst Du mal schauen? |
Ich dachte das "empty schema" issue wäre durch diesen Commit bereits behoben: Vermutlich nutzt der API Generator noch den alten Stand der Spec-Dateien (also älter als 23 Tage). |
BTW: Ich nutze zur Validierung von Freifunk API Dateien gegen das Freifunk Schema gerne: Mit diesem Docker Container: |
der generator wird auch bald umgestellt, hier entsteht die neue Version: https://freifunk.github.io/generator.api.freifunk.net/ |
alles bis auf den Generator sollte auch schon funktionieren, z.b. auch der api viewer unter http://api-viewer.freifunk.net/ |
Mit der Umstellung auf draft-7 im Rahmen des GSoC-Projekts sind die Regeln auch ein wenig strenger geworden und wir haben Fehler entdeckt, die uns vorher einfach nicht aufgefallen sind, z.b. https://api-viewer.freifunk.net/bamberg.html#validation Dort ist das networks-feld einfach in einer falschen ebene gelandet |
Unabhängig wie lange die draft-3 Freifunk JSON Schema noch im Einsatz sein werden, sollte diese nicht nur schematisch valide JSON Schema sein, sondern auch noch unproblematisch in der Handhabung werden.
Egal ob eine Soft-Migration zu draft-7 stattfinden wird (siehe auch #151) oder wie lange diese dauert, sollten wir die aktuellen draft-3 Freifunk JSON Schema Datei von Usability Problemen befreien.
Freifunk draft-3 JSON Schema sind aktuell problematisch
Unsere Freifunk JSON Schema sind zwar gemäß http://json-schema.org/draft-03/schema# valide JSON Schema Dateien, jedoch sind diese gleichzeitig "empty schema". Was ist das?
Ein "empty schema" ist ein JSON Schema das auf root-ebene keine der folgenden Schema Keywords enthält: https://tools.ietf.org/html/draft-zyp-json-schema-03#section-5
Nicht in der Spezifikation aufgeführte "Schema Keywords" werden ignoriert. Das steht in der Spec vom draft-3 zwar nicht explizit ist aber üblich unter den gängigen Validatoren - oft sogar ohne ein Hinweis auf das etwas ignoriert wurde. In der aktuellen draft-7 Spezifikation ist das Ignorieren aber explizit erwähnt: https://tools.ietf.org/html/draft-handrews-json-schema-01#section-4.3.1, was wirklich gut ist.
Da die Freifunk JSON Schema Dateien auf der Root-Ebene nur das Keyword "schema" (nicht verwechseln mit "$schema") verwenden und dieses nicht zur Spezifikation gehört wird es oft ignoriert und damit auch das eigentliche Freifunk JSON Schema welches sich eine Ebene tiefer befindet. Das führt dazu dass eine Validierung mit diesem JSON Schema zwangsläufig immer erfolgreich verlaufen ("empty schema"; da keine Regeln ausgewertet werden). Oder zumindest in einigen Validatoren anderes.
Einige Freifunk-Scripte (API Generator und o.g. Travis-CI Script) extrahieren daher den Teil unterhalb des "schema"-Feldes und bringen das damit auf Root-Ebene. Beispiel:
https://github.com/freifunk/directory.api.freifunk.net/blob/master/tests/test.py#L28
Ein unerfahrener Entwickler oder Anwender aus einer lokalen Gruppe könnte gar nicht bemerkt haben das unser Freifunk JSON Schema einen "wrapper" in sich hat, der es zu einem "empty schema" macht, und alle seine Dateien damit immer als valide ausgibt, obwohl sie es nicht wären, wenn man den "Extract" als JSON Schema verwendet.
Alle Scripte die nicht kurzfristig auf draft-7 umgestellt werden können (z.B. fehlende unterstützung für draft-7) sollten von uns zumindest semantisch-saubere draft-3 Dateien bekommen. Auch hier würde ich diese gerne zunächst Zusätzlich im Repo ablegen um eine Soft-Migration bis z.B. 31.12.2019 zu ermöglichen.
(dieses Ticket wird dann für die Commit-Message und den PR verwendet)
Was haltet Ihr davon?
The text was updated successfully, but these errors were encountered: