Skip to end of metadata
Go to start of metadata

You are viewing an old version of this page. View the current version.

Compare with Current View Page History

« Previous Version 2 Next »

Udkast til testscenarie 2

Scenariet er: Hent flere datapakker

Dette scenarie er en udvidelse af det første testscenarie. Her skal klienten hente en serie af datapakker. For nemheds skyld bliver der bedt om tre pakker i beskrivelsen forneden.
Man bør også teste med 10 og 100 pakker.
Den generelle kø benyttes indledende men herefter offloades resten af kommunikation til en privat kø, der her antages bare at "være til rådighed". Der benyttes samme conversationID til alle beskeder, sådan at hele forløbet kan følges på tværs af køer.

Setup for dette scenarie bygger i øvrigt på testscenarie #
scenariet går i 4 steps:

  • (1a) forespørgsel fra klient til pillars i SLA
  • (1b) svar fra pillars
  • (2a) specifik get fra klient til specifik pillar
  • (2b) svar i form a datatransmission

scenariet er først beskrevet via illustrationer (kommer...) og derefter ved konkrete værdier i generelle beskedformater med efterfølgende XML. Antagelser om de generelle formater er givet til sidst.

Step 1 a+b

Besked fra 1a

Besked sendes på "Topic General to pillars"

Besked fra 1a i det generelle format

Feltnavn

Klient1

!OperationId

!GetTime

!ConversationId

scen2

!PillarIds

pillar1, pillar2, pillar4

!DataIds

Id1, Id2, Id3

!ReplyQueueName

QReplyQueueTime

Token

undefined

Synchronous

undefined

Offset

undefined

Size

undefined

Beskeder2 fra 1a i XML

<message>
  <operationId>GetTime</operationId>
  <conversationId>scen2</conversationId>
  <pillarIds>
    <pillarId>pillar1</pillarId>
    <pillarId>pillar2</pillarId>
    <pillarId>pillar4</pillarId>
  </pillarIds>
  <dataIds>
    <dataId>Id1</dataId>
    <dataId>Id2</dataId>
    <dataId>Id3</dataId>
  </dataIds>
  <replyQueueName>QReplyQueueTime</replyQueueName>
</message>

Beskeder fra 1b

Beskeder som sendes på kø "QReplyQueueTime"

Beskeder fra 1b i generelle format

Feltnavn

Pillar 1

Pillar 1

Pillar 2

Pillar 4

!DataIds

Id1, Id3

Id2

Id1, Id2, Id3

none

!OperationId

!GetTimeReply

!GetTimeReply

!GetTimeReply

!GetTimeReply

!ConversationId

scen2

scen2

scen2

scen2

!PillarId

pillar1

pillar1

pillar2

pillar4

!TimeMeasure

6

2

2

undefined

!TimeUnit

min

sec

sec

undefined

!ErrorCode

undefined

undefined

undefined

47

  • Pillar 3 bør ikke svare, og pillar 4 svarer med error ligesom i testscenarie # Pillar 1 svarer med to svar da det er et near-online system og den ved at Id2 ligger online og Id1 og d3 begge ligger offline. *

Beskeder fra 1b i XML format

Pillar 1
<message>
  <operationId>GetTimeReply</operationId>
  <conversationId>scen2</conversationId>
  <pillarId>pillar1</pillarId>
  <dataIds>
    <dataId>Id1</dataId>
    <dataId>Id3</dataId>
</dataIds>
  <time>
    <measure>6</measure>
    <unit>min</unit>
  </time>
</message>
Pillar 1
<message>
  <operationId>GetTimeReply</operationId>
  <conversationId>scen2</conversationId>
  <pillarId>pillar1</pillarId>
  <dataIds>
    <dataId>Id2</dataId>
  </dataIds>
  <time>
    <measure>2</measure>
    <unit>sek</unit>
  </time>
</message>
Pillar 2
<message>
  <operationId>GetTimeReply</operationId>
  <conversationId>scen2</conversationId>
  <pillarId>pillar2</pillarId>
  <time>
    <measure>2</measure>
    <unit>sec</unit>
  </time>
</message>
Pillar 4
<message>
  <operationId>GetTimeReply</operationId>
  <conversationId>scen2</conversationId>
  <pillarId>pillar4</pillarId>
  <error>47</error>
</message>
  • I dette scenarie svarer Pillar 3 med et forkortet svar, hvor dataIds ikke gentages (se spørgsmål under scenarie 1). Hvis det er muligt at svare uden dataIds, kan det som her fortolkes som at svaret dækker alle datapakker. *

Step 2 a+b

Besked fra 2a

Besked sendes på "Klient1ToPillar2"

Besked fra 2a i generelle format

Feltnavn

msg1

msg2

msg3

!OperationId

Get

Get

Get

!ConversationId

scen2

scen2

scen2

!PillarIds

pillar2

pillar2

pillar2

!DataIds

Id1

Id2

Id3

!ReplyQueueName

undefined

undefined

undefined

Token

http:/a/b.data

http:/b/c.data

http:/c/d.data

Synchronous

undefined

undefined

undefined

Offset

undefined

undefined

undefined

Size

undefined

undefined

undefined

Den generelle kø benyttes indledende men herefter offloades resten af kommunikation til en privat kø, der her antages bare at "være til rådighed". Der benyttes samme conversationID til alle beskeder, sådan at hele forløbet kan følges på tværs af køer.

Besked fra 2a i XML format

Msg1
<message>
  <operationId>Get</operationId>
  <conversationId>scen2</conversationId>
  <pillarIds>
    <pillarId>pillar2</pillarId>
  </pillarIds>
  <dataIds>
    <dataId>Id1</dataId>
  </dataIds>
  <token>http:/a/b.data</token>
</message>
Msg2
<message>
  <operationId>Get</operationId>
  <conversationId>scen2</conversationId>
  <pillarIds>
    <pillarId>pillar2</pillarId>
  </pillarIds>
  <dataIds>
    <dataId>Id2</dataId>
  </dataIds>
  <token>http:/b/c.data</token>
</message>
Msg3
<message>
  <operationId>Get</operationId>
  <conversationId>scen2</conversationId>
  <pillarIds>
    <pillarId>pillar2</pillarId>
  </pillarIds>
  <dataIds>
    <dataId>Id3</dataId>
  </dataIds>
  <token>http:/a/b.data</token>
</message>

Dataoverførelse fra 2b

  • Dataoverførelse af pakken Id1 via http:/a/b.data fra pillar 2
  • Dataoverførelse af pakken Id2 via http:/b/c.data fra pillar 2
  • Dataoverførelse af pakken Id3 via http:/c/d.data fra pillar 2

Spørgsmål og mulige udvidelser

  • *I praksis kunne det være rart at vide hvor lang tid det tager at oprette/nedlægge en kø. Hvis det lang tid, giver det så mening, at etablere private køer? Hvis alternativet er, at oprette alle (SLA-) relevante kombinationer af klineter/pillars, etc. *
  • *Udvide den indledende forespørgsel på pillars, så der også returneres hvilke datapakker, der er til rådighed. Dette er nødvendigt for near-offline pillars, hvor der kan være forskellige klargøringstider pr. pakke. (Alternativt: At begrænse antallet af dataIDs til en pr. forespørgsel. *
  • *I forlængelse af det ovenstående. Hvis listen af dataID er magen til den oprindeligt udsendte, behøver man ikke at sende den med tilbage. (Se f.eks pillar2's svar foroven) *
  • *Tæller offsett fra 0 eller 1? *
  • *Er det korrekt, at tokens er angivet med http og ikke https? *
  • *Er det ok, at droppe pillarIds i private køer? *
  • No labels