diff --git a/test/core/thing_description_test.dart b/test/core/thing_description_test.dart index 20c72926..84476db7 100644 --- a/test/core/thing_description_test.dart +++ b/test/core/thing_description_test.dart @@ -39,6 +39,67 @@ void main() { expect(thingDescriptionJson, thingDescription.toJson()); }); + test( + "be able to created via its constructor " + "and converted to a Map", () { + const thingDescriptionJson = { + "@context": [ + "https://www.w3.org/2022/wot/td/v1.1", + {"@language": "de"}, + ], + "title": "Test Thing", + "securityDefinitions": { + "nosec_sc": {"scheme": "nosec"}, + }, + "security": ["nosec_sc"], + "properties": { + "status": { + "type": "string", + "forms": [ + { + "href": "https://example.org", + } + ], + }, + }, + }; + + final thingDescription = ThingDescription( + context: Context( + [ + SingleContextEntry( + Uri.parse("https://www.w3.org/2022/wot/td/v1.1"), + ), + const StringMapContextEntry( + "@language", + "de", + ), + ], + ), + title: "Test Thing", + security: const [ + "nosec_sc", + ], + securityDefinitions: const { + "nosec_sc": NoSecurityScheme(), + }, + properties: { + "status": Property( + forms: [ + Form( + Uri.parse("https://example.org"), + ), + ], + dataSchema: const DataSchema( + type: "string", + ), + ), + }, + ); + + expect(thingDescriptionJson, thingDescription.toJson()); + }); + test("throw a FormatException when it is invalid during parsing", () { const thingDescriptionJson = { "@context": [