FHIRPath

FHIRPath assertions can be evaluated against payloads of both request and response variables offered by the Touchstone Rules-Engine. The same FHIRPath expression will work against both XML and JSON content. However, FHIRPath assertions run significantly slower than XPath assertions and JsonPath assertions.

  • assertFhirPathBoolean(fhirpath)

    • Asserts that the evaluated value of the provided fhirpath expression is true

    • Example:

      // Asserts that the number of resource id elements in the response is 10
      response.assertFhirPathBoolean("entry.resource.id.count() = 10")
      
    • Equivalent to each of these:

      • assertFhirPathBoolean("entry.resource.id.count() = 10", response)
        
      • assert response.getFhirPathBoolean("entry.resource.id.count() = 10") : "The
           expression \"entry.resource.id.count() != 10\" evaluated to false"
        
      • assert response.fhirPathBoolean("entry.resource.id.count() = 10") : "The
           expression \"entry.resource.id.count() != 10\" evaluated to false"
        
  • assertFhirPathContains(fhirpath, expectedValue)

    • Asserts that the evaluated value of the provided fhirpath expression contains the provided expectedValue.

    • Example:

      // Asserts that the value of the family element of the second entry contains 'Chalmers'
      response.assertFhirPathContains("entry[1].resource.name.family", "Chalmers")
      
    • Equivalent to each of these:

      • assertFhirPathContains("entry[1].resource.name.family", "Chalmers", response)
        
      • // fhirPath, expectedValue, and operator can be passed as parameters from test script.
        assertFhirPath("entry[1].resource.name.family", "Chalmers", "contains", response)
        
      • def family = response.getFhirPathValue("entry[1].resource.name.family")
        
        assert family.contains("Chalmers"): "The actual value \""+family+"\" did not contain the expected value
           \"Chalmers\" for \"entry[1].resource.name.family\" in response."
        
      • def family = response.fhirPathValue("entry[1].resource.name.family")
        
        assert containsIgnoreCase("chalmers", family): "The actual value \""+family+"\" did not contain the expected value
           \"Chalmers\"  for \"entry[1].resource.name.family\" in response."
        
      • def family = response.fhirPath("entry[1].resource.name.family").value
        
        assert contains("Chalmers", family): "The actual value \""+family+"\" did not contain the expected value
           \"Chalmers\"  for \"entry[1].resource.name.family\" in response."
        

        Notice how the value of a FHIRPath evaluation can be stored in a variable. This is useful when you want to develop more complicated rule scripts where the assertions involve multiple comparisons.

  • assertFhirPathNotContains(fhirpath, expectedValue)

    • Asserts that the evaluated value of the provided fhirpath expression does not contain the provided expectedValue.

    • Example:

      // Asserts that the value of the family element of the second entry contains 'Chalmers'
      response.assertFhirPathNotContains("entry[1].resource.name.family", "Chalmers")
      
    • Equivalent to each of these:

      • assertFhirPathNotContains("entry[1].resource.name.family", "Chalmers", response)
        
      • // fhirPath, expectedValue, and operator can be passed as parameters from test script.
        assertFhirPath("entry[1].resource.name.family", "Chalmers", "notContains", response)
        
      • def family = response.getFhirPathValue("entry[1].resource.name.family")
        
        assert !family.contains("Chalmers"): "The actual value \""+family+"\" contained the expected value
           \"Chalmers\" for \"entry[1].resource.name.family\" with operator 'notContains' in response."
        
      • def family = response.fhirPathValue("entry[1].resource.name.family")
        
        assert notContainsIgnoreCase("chalmers", family): "The actual value \""+family+"\" contained the expected value
           \"Chalmers\"  for \"entry[1].resource.name.family\" with operator 'notContains' in response."
        
      • def family = response.fhirPath("entry[1].resource.name.family").value
        
        assert notContains("Chalmers", family): "The actual value \""+family+"\" contained the expected value
           \"Chalmers\"  for \"entry[1].resource.name.family\" with operator 'notContains' in response."
        
  • assertFhirPathEmpty(fhirpath)

    • Asserts that the evaluated value of the provided fhirpath expression is absent or empty.

    • Example:

      response.assertFhirPathEmpty("entry[0].resource.photo.title")
      
    • Equivalent to these:

      assertFhirPathEmpty("entry[0].resource.photo.title", response)
      
      response.fhirPath("entry[0].resource.photo.title").empty();
      
      def title = response.getFhirPathValue("entry[0].resource.photo.title")
      
      assert !title: "Expected title to be absent but was present in response"
      
      def title = response.fhirPathValue("entry[0].resource.photo.title")
      
      assert title==null: "Expected title to be absent but was present in response"
      
      def title = response.fhirPath("entry[0].resource.photo.title").value
      
      assert empty(title): "Expected title to be absent but was present in response"
      
  • assertFhirPathNotEmpty(fhirpath)

    • Asserts that the evaluated value of the provided fhirpath expression is present and not empty.

    • Example:

      response.assertFhirPathNotEmpty("entry[0].resource.birthDate")
      
    • Equivalent to these:

      assertFhirPathNotEmpty("entry[0].resource.birthDate", response)
      
      response.fhirPath("entry[0].resource.birthDate").notEmpty();
      
      def title = response.getFhirPathValue("entry[0].resource.birthDate")
      
      assert title: "Expected birthDate to be absent but was present in response"
      
      def title = response.fhirPathValue("entry[0].resource.birthDate")
      
      assert title!=null: "Expected birthDate to be absent but was present in response"
      
      def title = response.fhirPath("entry[0].resource.birthDate").value
      
      assert notEmpty(title): "Expected birthDate to be absent but was present in response"
      
  • assertFhirPathEquals(fhirpath, expectedValue)

    • Asserts that the evaluated value of the provided fhirpath expression matches the provided expectedValue.

    • Example:

      // Asserts that the value of the family element of the first entry is 'Chalmers'
      response.assertFhirPathEquals("entry[0].resource.name.family", "Chalmers")
      
    • Equivalent to each of these:

      • assertFhirPathEquals("entry[0].resource.name.family", "Chalmers", response)
        
      • // fhirPath, expectedValue, and operator can be passed as parameters from test script.
        assertFhirPath("entry[0].resource.name.family", "Chalmers", "equals", response)
        
      • def family = response.getFhirPathValue("entry[0].resource.name.family")
        
        assert family.equals("Chalmers"): "The actual value \""+family+"\" did not match the expected value
        \"Chalmers\" for \"entry[0].resource.name.family\" in response."
        
      • def family = response.fhirPathValue("entry[0].resource.name.family")
        
        assert equalsIgnoreCase("chalmers", family): "The actual value \""+family+"\" did not match the expected value
           \"Chalmers\"  for \"entry[0].resource.name.family\" in response."
        
      • def family = response.fhirPath("entry[0].resource.name.family").getValue()
        
        assert equals("Chalmers", family): "The actual value \""+family+"\" did not match the expected value
           \"Chalmers\"  for \"entry[0].resource.name.family\" in response."
        
      • def family = response.fhirPath("entry[0].resource.name.family").value
        
        assert family == "Chalmers": "The actual value \""+family+"\" did not match the expected value
           \"Chalmers\" for \"entry[0].resource.name.family\" in response."
        
  • assertFhirPathNotEquals(fhirpath, expectedValue)

    • Asserts that the evaluated value of the provided fhirpath expression does not match the provided expectedValue.

    • Example:

      // Asserts that values of the family element of the first entry is not 'Chalmers'
      response.assertFhirPathNotEquals("entry[0].resource.name.family", "Chalmers")
      
    • Equivalent to each of these:

      • assertFhirPathNotEquals("entry[0].resource.name.family", "Chalmers", response)
        
      • // fhirPath, expectedValue, and operator can be passed as parameters from test script.
        assertFhirPath("entry[0].resource.name.family", "Chalmers", "notEquals", response)
        
      • def family = response.getFhirPathValue("entry[0].resource.name.family")
        
        assert !family.equals("Chalmers"): "The actual value \""+family+"\" matched
           the expected value \"Chalmers\" for \"entry[0].resource.name.family\" with operator
              'notEquals' in response."
        
      • def family = response.fhirPathValue("entry[0].resource.name.family")
        
        assert notEqualsIgnoreCase("chalmers", family): "The actual value \""+family+"\" matched
           the expected value \"Chalmers\" for \"entry[0].resource.name.family\" with operator
              'notEquals' in response."
        
      • def family = response.fhirPath("entry[0].resource.name.family").getValue()
        
        assert family != "Chalmers": "The actual value \""+family+"\" matched
           the expected value \"Chalmers\" for \"entry[0].resource.name.family\" with operator
              'notEquals' in response."
        
      • def family = response.fhirPath("entry[0].resource.name.family").value
        
        assert notEquals("Chalmers", family): "The actual value \""+family+"\" matched
           the expected value \"Chalmers\" for \"entry[0].resource.name.family\" with operator
              'notEquals' in response."
        
  • assertFhirPathGreaterThan(fhirpath, expectedValue)

    • Asserts that the evaluated value of the provided fhirpath expression is greater than the provided expectedValue.

    • Example:

      // Asserts that resource id of the second entry is greater than 1100 in the response
      response.assertFhirPathGreaterThan("entry[1].resource.id", 1100)
      
    • Equivalent to each of these:

      • assertFhirPathGreaterThan("entry[1].resource.id", 1100, response)
        
      • // fhirPath, expectedValue, and operator can be passed as parameters from test script.
        assertFhirPath("entry[1].resource.id", "1100", "greaterThan", response)
        
      • def id = response.getFhirPathValue("entry[1].resource.id")
        
        assert id.toInteger() > 1100: "Expected \"entry[1].resource.id\" to be greater than 5000
            but was "+id+" in response"
        
      • def id = response.fhirPathValue("entry[1].resource.id")
        
        assert (id as Integer) > 1100: "Expected \"entry[1].resource.id\" to be greater than 5000
           but was "+id+" in response"
        
      • def id = response.fhirPath("entry[1].resource.id").value
        
        assert greaterThan(1100, id): "Expected \"entry[1].resource.id\" to be greater than 5000
           but was "+id+" in response"
        
  • assertFhirPathLessThan(fhirpath, expectedValue)

    • Asserts that the evaluated value of the provided fhirpath expression is less than the provided expectedValue.

    • Example:

      // Asserts that resource id of the second entry is less than 1100 in the response
      response.assertFhirPathLessThan("entry[1].resource.id", 1100)
      
    • Equivalent to each of these:

      • assertFhirPathLessThan("entry[1].resource.id", 1100, response)
        
      • // fhirPath, expectedValue, and operator can be passed as parameters from test script.
        assertFhirPath("entry[1].resource.id", "1100", "lessThan", response)
        
      • def id = response.getFhirPathValue("entry[1].resource.id")
        
        assert id.toInteger() < 1100: "Expected \"entry[1].resource.id\" to be less than 5000
            but was "+id+" in response"
        
      • def id = response.fhirPath("entry[1].resource.id").getValue()
        
        assert (id as Integer) < 1100: "Expected \"entry[1].resource.id\" to be less than 5000
           but was "+id+" in response"
        
      • def id = response.fhirPath("entry[1].resource.id").value
        
        assert lessThan(1100, id): "Expected \"entry[1].resource.id\" to be less than 5000
           but was "+id+" in response"
        
  • assertFhirPathIn(fhirpath, expectedValues)

    • Asserts that the evaluated value of the provided fhirpath expression is one of the provided expectedValues where each value is separated by a comma.

    • Example:

      // Asserts that resource id of the second entry is either 1100 or 1101 or 1102
      response.assertFhirPathIn("entry[1].resource.id", "1100,1101,1102")
      
    • Equivalent to each of these:

      • assertFhirPathIn("entry[1].resource.id", "1100,1101,1102", response)
        
      • // fhirPath, expectedValue, and operator can be passed as parameters from test script.
        assertFhirPath("entry[1].resource.id", "1100,1101,1102", "in", response)
        
      • def id = response.getFhirPathValue("entry[1].resource.id")
        
        assert id in ["1100", "1101", "1102"]: "Expected one of the values in [1100, 1101, 1102]
           for \"entry[1].resource.id\" but encountered \""+id+"\" in response."
        
      • def id = response.fhirPath("entry[1].resource.id").value
        
        assert isIn("1100,1101,1102", id): "Expected one of the values in [1100, 1101, 1102] for
           \"entry[1].resource.id\" but encountered \""+id+"\" in response."
        
  • assertFhirPathNotIn(fhirpath, expectedValues)

    • Asserts that the evaluated value of the provided fhirpath expression is none of the provided expectedValues where each value is separated by a comma.

    • Example:

      // Asserts that resource id of the second entry is either 1100 or 1101 or 1102
      response.assertFhirPathNotIn("entry[1].resource.id", "1100,1101,1102")
      
    • Equivalent to each of these:

      • assertFhirPathNotIn("entry[1].resource.id", "1100,1101,1102", response)
        
      • // fhirPath, expectedValue, and operator can be passed as parameters from test script.
        assertFhirPath("entry[1].resource.id", "1100,1101,1102", "notIn", response)
        
      • def id = response.getFhirPathValue("entry[1].resource.id")
        
        assert !(id in ["1100", "1101", "1102"]): "Expected none of the values in [1100, 1101, 1102]
           for \"entry[1].resource.id\" but encountered \""+id+"\" with operator 'notIn' in response."
        
      • def id = response.fhirPath("entry[1].resource.id").value
        
        assert isNotIn("1100,1101,1102", id): "Expected none of the values in [1100, 1101, 1102] for
           \"entry[1].resource.id\" but encountered \""+id+"\" with operator 'notIn' in response."