Metadata & Instance Test Cases
You will need to pre-populate the AppDirectory with the following items:
| App | Required Metadata | 
|---|---|
| A | Generic AppD Record which contains at least the following fields: - name- version- title- tooltip- description- icons(Array<Icon>)- screenshots(Array<Image>)- interop.intents.listensFor(aTestingIntentwith at least context typetestContextX) | 
Retrieve AppMetadata  
| App | Step | Details | 
|---|---|---|
| Test | 1.getAppMetadata | Retrieve metadata for the configured app A with const metadata1 = await fdc3.getAppMetadata({appId: "<A's appId>"}) | 
| Test | 2.Confirm | Compare the AppMetadataobject to the expected definition for the fields provided above during setup and ensure that the metadata matches. AninstanceIdshould NOT be set | 
- GetAppMetadata: perform the above steps
Instance Metadata  
| App | Step | Details | 
|---|---|---|
| Test | 1.Open1 | Open a first instance of App A using const appIdentifier1 = await fdc3.open({appId: "<A's appId>"})and confirm that its AppIdentifiercontains aninstanceId. | 
| Test | 2.Open2 | Open a second instance of App A using const appIdentifier2 = await fdc3.open({appId: "<A's appId>"})and confirm that its AppIdentifiercontains aninstanceIdand that its value differs from that returned for the first instance. | 
| Test | 3.getAppMetadata1 | Retrieve metadata for the first instance of the app with const metadata1 = fdc3.getAppMetadata(appIdentifier1) | 
| Test | 4.Confirm1 | Compare the AppMetadataobject to the expected definition for the fields provided above during setup and ensure that the metadata matches. | 
| Test | 5.getAppMetadata2 | Retrieve metadata for the second instance of the app with const metadata2 = fdc3.getAppMetadata(appIdentifier2) | 
| Test | 6.Confirm2 | An instanceIdshould be provided, confirm that it matches the one inappIdentifier2 | 
- AppInstanceMetadata: Perform the above steps
Finding Instances  
| App | Step | Details | 
|---|---|---|
| Test | 1.Open1 | Open the first instance of App A using const appIdentifier1 = await fdc3.open({appId: "<A's appId>"})and confirm that its AppIdentifiercontains aninstanceId. | 
| Test | 2.Open2 | Open a second instance of App A using const appIdentifier2 = await fdc3.open({appId: "<A's appId>"})and confirm that its AppIdentifiercontains aninstanceIdand that its value differs from that returned for the first instance. | 
| Test | 3.FindInstances | Retrieve details of open instances of app A with let instances = await fdc3.findInstances({appId: "<A's appId>"})confirm that both appIdentifier1andappIdentifier2are both present in the array. | 
| Test | 4.RaiseIntent | Use appIdentifier1to raise an intent and target that instance, withconst resolution = fdc3.raiseIntent("aTestingIntent", {"type": "testContextX"}, appIdentifier1) | 
| Test | 5.Confirm1 | Check that resolution.sourcematchesappIdentifier1 | 
| A | 6.ConfirmReceipt | Ensure that the instance of app A represented by appIdentifier1received the raised intent | 
- FindInstances: Perform the above steps
Getting Info For The Agent
| App | Step | Details | 
|---|---|---|
| Test | 1.getInfo | Retrieve the ImplementationMetadatafor the DesktopAgent with- let implMetadata = fdc3.getInfo()- fdc3.getInfo().then((implMetadata) => { subsequent steps }Note that the use of thenis deliberate and intended to confirm that a promise returned (as this function switched from synchronous to asynchronous in 2.0) | 
| Test | 2.CheckVersion | Check that the fdc3Versionvariable is present and at or greater than:- - (which you can do with the versionIsAtLeastfunction from FDC3's Methods.ts:const isFDC3v2 = versionIsAtLeast(implMetadata, "2.0") | 
| Test | 3.CheckProvider | Check that the providervariable is present and not an empty string | 
| Test | 4.CheckFeatures | optionalFeatures,optionalFeatures.OriginatingAppMetadataandoptionalFeatures.UserChannelMembershipAPIsvariables are all present and that the latter two provide boolean values | 
- GetInfo1: Perform the above steps
| App | Step | Details | 
|---|---|---|
| Test | 1.Open1 | Start an instance of App A with const appIdentifier1 = await fdc3.open({appId: "<A's appId>"})retrieve its AppIdentifierwith instance details. Confirm that theAppIdentifiercontains both anappIdandinstanceId | 
| A | 2.getInfo | Retrieve the ImplementationMetadatafor the DesktopAgent with:fdc3.getInfo().then((implMetadata) => {  ... subsequent steps ...}This should include AppMetadatafor the retrieving app. | 
| A + Test | 3.Confirm | Check that implMetadata.appMetadatacontains anappIdandinstanceIdmatching that retrieved in the first step (will require transmission of the details from A to Test or vice-versa). Also compare theAppMetadataobject to the expected definition for the fields provided above during setup and ensure that the metadata matches. | 
- GetInfo2: Perform the above steps.