Testdaten für ein XML Schema generieren

vorhergehende Artikel in: Java Komponenten OpenSource
01.05.2020

Ich suche immer wieder nach neuen Ideen, möglichst einfach problemangepasste Testdaten zu erzeugen. Diesmal habe ich damit begonnen, XML-Dokumente zu erzeugen, die einem vorgegebenen XML-Schema genügen sollten

Überblick

SchemaAnalyzer Ich hatte bereits einige Male über ein solches Projekt nachgedacht, es aber immer wieder verworfen - bis ich einen Artikel fand, der beschrieb, wie man Daten entsprechend einer vorliegenden Backus-Naur-Form erzeugen könnte. Ich fand bei meinen Recherchen zwar allerlei Nützliches zur Arbeit mit Grammatiken, wurde aber auch wieder an die uralte Idee der Erzeugung von Daten einem XML-Schema folgend erinnert

Das inspirierte mich, noch einmal über dieses Thema nachzudenken. Einer der Gründe, die mich bisher immer davon abhielten war die Tatsache, dass XML Schema recht komplex und schwer zu parsen ist - auch wenn es einige ausgezeichnete Ressourcen dazu im Netz gibt.

Jetzt fand ich aber eine Bibliothek - xmlbeans -, die einen Schema-Parser beinhaltet, der alle meine Wünsche erfüllte - damit konnte ich das Projekt angehen, ohne mich um den Parser kümmern zu müssen und konnte mich ganz auf die Datengenerierung konzentrieren.

Roadmap

Diese Komponente wird die Erstellung gültiger XML-Dokumente für ein vorgegebenes XML-Schema (version 1.0) realisieren. Es wird eine Untermenge der XML-Schema-Version 1.0 (a http://www.w3.org/2001/XMLSchema unterstützt - siehe dazu auch hier.

Diese Funktionalität kann für die Erstellung von Testdaten oder zum Fuzzing von Schnittstellen eingesetzt werden. Die erzeugten Daten können über das generierte XML-Dokument unter Verwendung von XSLT-Transformationen in andere gewünschte textbasierte Repräsentationen überführt werden.

Alle nicht nachstehend explizit genannten Features werden nicht unterstützt!

Die Komponente nimmt ein XML-Schema-Dokument entgegen und erzeugt ein gültiges Instanz-Dokument für den Dokument-Typ wenn exakt einer existiert. Existieren mehrere Dokumenttypen, muss der Anwender den gewünschten durch Angabe dessen Namens identifizieren.

Version 0.9

Der Inhalt der Attribute und Elemente wird entsprechend der im Schema vorgefundenen Regeln und Einschränkungen vollkommen artifiziell - ohne jede Semantik - generiert!

Schema

Es werden nur Elemente unterstützt - kein mixed type! Attribute werden ebenfalls unterstützt.

Indicators

Unterstützt werden:

  • All
  • Choice
  • Sequence
  • maxOccurs
  • minOccurs

Attributes

Unterstützt werden:

  • Optional
  • Required

Datatypes

Unterstützt werden (siehe auch):

Primitive datatypes

  • string
  • boolean
  • decimal
  • float
  • double
  • duration
  • dateTime
  • time
  • date
  • gYearMonth
  • gYear
  • gMonthDay
  • gDay
  • gMonth
  • hexBinary
  • base64Binary
  • anyURI

Derived datatypes

  • normalizedString
  • token
  • language
  • integer
  • nonPositiveInteger
  • negativeInteger
  • long
  • int
  • short
  • byte
  • nonNegativeInteger
  • unsignedLong
  • unsignedInt
  • unsignedShort
  • unsignedByte
  • positiveInteger
  • NCName
  • ID
  • NMToken

Restrictions

Unterstützt werden )abhängig von der Verfügbarkeit der jeweiligen Restriction für den in Frage stehenden Datentyp):

  • enumeration
  • fractionDigits
  • length
  • maxExclusive
  • maxInclusive
  • maxLength
  • minExclusive
  • minInclusive
  • minLength
  • pattern
  • totalDigits

Version 1.0

Features:

  • Version 0.9
  • Zusätzlich wird es möglich sein, Generatoren für bestimmte Elemente anzugeben, um dem entstehenden Dokument eine bessere Semantik zu verleihen.
  • Substitution Groups
  • Type Hierachies und abstrakte Typen

Artikel, die hierher verlinken

Testdaten für ein XML Schema generieren - v1.0.0

04.02.2021

Nachdem ich hier bereits den Generator für XML entsprechend vorgegebener XML-Schemata vorgestellt hatte - hier nun ein Update dazu

OpenApi-Schema Testdaten-Generator

07.11.2020

Ich berichtete neulich darüber, dass ich nunmehr mit einem Builder-Pattern beliebig komplexe JSON-Strukturen generieren kann.

Generator-Framework in JMeter integriert

27.09.2020

Nachdem ich neulich zwei neue Container für Software-Tests zu meinem Docker-Zoo hinzugefügt habe ist es nun an der Zeit, ein weiteres Hilfsmittel für Software-Tests mit JMeter vorzustellen

Json-Builder im Generator-Framework

15.09.2020

Nachdem ich vor einiger Zeit darüber berichtete, dass mein Framework zur Generierung von Testdaten jetzt in der Lage ist, valide XML-Dokumente nach vorgegebenen XML-Schemata zu erzeugen habe ich eine weitere Funktionalität zu diesem Framework hinzugefügt:

Alle Artikel rss Wochenübersicht Monatsübersicht Codeberg Repositories Mastodon Über mich home xmpp


Vor 5 Jahren hier im Blog

  • Vorhaben 2020

    03.01.2020

    Genau wie letztes Jahr habe ich auch dieses Jahr wieder ein "Listche" verfasst, um mir all die interessanten Vorhaben zu notieren, die ich mit mittlerem zeitlichen Horizont anzugehen gedenke.

    Weiterlesen...

Neueste Artikel

  • Migration der Webseite und aller OpenSource Projekte

    In eigener Sache...

    Weiterlesen...
  • 38c3 - Nachlese

    Nach dem ersten Teil von mir als interessant eingestufter Vorträge des Chaos Communication Congress 2024 hier nun die Nachlese

    Weiterlesen...
  • 38c3 - Empfehlungen

    Nach dem So - wie auch im letzten Jahr: Meine Empfehlungen für Vorträge vom Chaos Communication Congress 2024 - vulgo: 38c3:

    Weiterlesen...

Manche nennen es Blog, manche Web-Seite - ich schreibe hier hin und wieder über meine Erlebnisse, Rückschläge und Erleuchtungen bei meinen Hobbies.

Wer daran teilhaben und eventuell sogar davon profitieren möchte, muss damit leben, daß ich hin und wieder kleine Ausflüge in Bereiche mache, die nichts mit IT, Administration oder Softwareentwicklung zu tun haben.

Ich wünsche allen Lesern viel Spaß und hin und wieder einen kleinen AHA!-Effekt...

PS: Meine öffentlichen Codeberg-Repositories findet man hier.