All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.hl7.fhir.r4.model.TestReport Maven / Gradle / Ivy

Go to download

Builds the hapi fhir r4. Requires hapi-fhir-base and hapi-fhir-utilities be built first and be excluded from any other poms requiring it.

The newest version!
package org.hl7.fhir.r4.model;

import java.math.BigDecimal;

/*
  Copyright (c) 2011+, HL7, Inc.
  All rights reserved.
  
  Redistribution and use in source and binary forms, with or without modification, 
  are permitted provided that the following conditions are met:
  
   * Redistributions of source code must retain the above copyright notice, this 
     list of conditions and the following disclaimer.
   * Redistributions in binary form must reproduce the above copyright notice, 
     this list of conditions and the following disclaimer in the documentation 
     and/or other materials provided with the distribution.
   * Neither the name of HL7 nor the names of its contributors may be used to 
     endorse or promote products derived from this software without specific 
     prior written permission.
  
  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND 
  ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED 
  WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 
  IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, 
  INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 
  NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR 
  PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 
  WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 
  ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 
  POSSIBILITY OF SUCH DAMAGE.
  
*/

// Generated on Tue, May 12, 2020 07:26+1000 for FHIR v4.0.1
import java.util.ArrayList;
import java.util.Date;
import java.util.List;

import org.hl7.fhir.exceptions.FHIRException;
import org.hl7.fhir.instance.model.api.IBaseBackboneElement;
import org.hl7.fhir.utilities.Utilities;

import ca.uhn.fhir.model.api.annotation.Block;
import ca.uhn.fhir.model.api.annotation.Child;
import ca.uhn.fhir.model.api.annotation.Description;
import ca.uhn.fhir.model.api.annotation.ResourceDef;
import ca.uhn.fhir.model.api.annotation.SearchParamDefinition;

/**
 * A summary of information based on the results of executing a TestScript.
 */
@ResourceDef(name = "TestReport", profile = "http://hl7.org/fhir/StructureDefinition/TestReport")
public class TestReport extends DomainResource {

  public enum TestReportStatus {
    /**
     * All test operations have completed.
     */
    COMPLETED,
    /**
     * A test operations is currently executing.
     */
    INPROGRESS,
    /**
     * A test operation is waiting for an external client request.
     */
    WAITING,
    /**
     * The test script execution was manually stopped.
     */
    STOPPED,
    /**
     * This test report was entered or created in error.
     */
    ENTEREDINERROR,
    /**
     * added to help the parsers with the generic types
     */
    NULL;

    public static TestReportStatus fromCode(String codeString) throws FHIRException {
      if (codeString == null || "".equals(codeString))
        return null;
      if ("completed".equals(codeString))
        return COMPLETED;
      if ("in-progress".equals(codeString))
        return INPROGRESS;
      if ("waiting".equals(codeString))
        return WAITING;
      if ("stopped".equals(codeString))
        return STOPPED;
      if ("entered-in-error".equals(codeString))
        return ENTEREDINERROR;
      if (Configuration.isAcceptInvalidEnums())
        return null;
      else
        throw new FHIRException("Unknown TestReportStatus code '" + codeString + "'");
    }

    public String toCode() {
      switch (this) {
      case COMPLETED:
        return "completed";
      case INPROGRESS:
        return "in-progress";
      case WAITING:
        return "waiting";
      case STOPPED:
        return "stopped";
      case ENTEREDINERROR:
        return "entered-in-error";
      case NULL:
        return null;
      default:
        return "?";
      }
    }

    public String getSystem() {
      switch (this) {
      case COMPLETED:
        return "http://hl7.org/fhir/report-status-codes";
      case INPROGRESS:
        return "http://hl7.org/fhir/report-status-codes";
      case WAITING:
        return "http://hl7.org/fhir/report-status-codes";
      case STOPPED:
        return "http://hl7.org/fhir/report-status-codes";
      case ENTEREDINERROR:
        return "http://hl7.org/fhir/report-status-codes";
      case NULL:
        return null;
      default:
        return "?";
      }
    }

    public String getDefinition() {
      switch (this) {
      case COMPLETED:
        return "All test operations have completed.";
      case INPROGRESS:
        return "A test operations is currently executing.";
      case WAITING:
        return "A test operation is waiting for an external client request.";
      case STOPPED:
        return "The test script execution was manually stopped.";
      case ENTEREDINERROR:
        return "This test report was entered or created in error.";
      case NULL:
        return null;
      default:
        return "?";
      }
    }

    public String getDisplay() {
      switch (this) {
      case COMPLETED:
        return "Completed";
      case INPROGRESS:
        return "In Progress";
      case WAITING:
        return "Waiting";
      case STOPPED:
        return "Stopped";
      case ENTEREDINERROR:
        return "Entered In Error";
      case NULL:
        return null;
      default:
        return "?";
      }
    }
  }

  public static class TestReportStatusEnumFactory implements EnumFactory {
    public TestReportStatus fromCode(String codeString) throws IllegalArgumentException {
      if (codeString == null || "".equals(codeString))
        if (codeString == null || "".equals(codeString))
          return null;
      if ("completed".equals(codeString))
        return TestReportStatus.COMPLETED;
      if ("in-progress".equals(codeString))
        return TestReportStatus.INPROGRESS;
      if ("waiting".equals(codeString))
        return TestReportStatus.WAITING;
      if ("stopped".equals(codeString))
        return TestReportStatus.STOPPED;
      if ("entered-in-error".equals(codeString))
        return TestReportStatus.ENTEREDINERROR;
      throw new IllegalArgumentException("Unknown TestReportStatus code '" + codeString + "'");
    }

    public Enumeration fromType(PrimitiveType code) throws FHIRException {
      if (code == null)
        return null;
      if (code.isEmpty())
        return new Enumeration(this, TestReportStatus.NULL, code);
      String codeString = code.asStringValue();
      if (codeString == null || "".equals(codeString))
        return new Enumeration(this, TestReportStatus.NULL, code);
      if ("completed".equals(codeString))
        return new Enumeration(this, TestReportStatus.COMPLETED, code);
      if ("in-progress".equals(codeString))
        return new Enumeration(this, TestReportStatus.INPROGRESS, code);
      if ("waiting".equals(codeString))
        return new Enumeration(this, TestReportStatus.WAITING, code);
      if ("stopped".equals(codeString))
        return new Enumeration(this, TestReportStatus.STOPPED, code);
      if ("entered-in-error".equals(codeString))
        return new Enumeration(this, TestReportStatus.ENTEREDINERROR, code);
      throw new FHIRException("Unknown TestReportStatus code '" + codeString + "'");
    }

    public String toCode(TestReportStatus code) {
      if (code == TestReportStatus.COMPLETED)
        return "completed";
      if (code == TestReportStatus.INPROGRESS)
        return "in-progress";
      if (code == TestReportStatus.WAITING)
        return "waiting";
      if (code == TestReportStatus.STOPPED)
        return "stopped";
      if (code == TestReportStatus.ENTEREDINERROR)
        return "entered-in-error";
      return "?";
    }

    public String toSystem(TestReportStatus code) {
      return code.getSystem();
    }
  }

  public enum TestReportResult {
    /**
     * All test operations successfully passed all asserts.
     */
    PASS,
    /**
     * One or more test operations failed one or more asserts.
     */
    FAIL,
    /**
     * One or more test operations is pending execution completion.
     */
    PENDING,
    /**
     * added to help the parsers with the generic types
     */
    NULL;

    public static TestReportResult fromCode(String codeString) throws FHIRException {
      if (codeString == null || "".equals(codeString))
        return null;
      if ("pass".equals(codeString))
        return PASS;
      if ("fail".equals(codeString))
        return FAIL;
      if ("pending".equals(codeString))
        return PENDING;
      if (Configuration.isAcceptInvalidEnums())
        return null;
      else
        throw new FHIRException("Unknown TestReportResult code '" + codeString + "'");
    }

    public String toCode() {
      switch (this) {
      case PASS:
        return "pass";
      case FAIL:
        return "fail";
      case PENDING:
        return "pending";
      case NULL:
        return null;
      default:
        return "?";
      }
    }

    public String getSystem() {
      switch (this) {
      case PASS:
        return "http://hl7.org/fhir/report-result-codes";
      case FAIL:
        return "http://hl7.org/fhir/report-result-codes";
      case PENDING:
        return "http://hl7.org/fhir/report-result-codes";
      case NULL:
        return null;
      default:
        return "?";
      }
    }

    public String getDefinition() {
      switch (this) {
      case PASS:
        return "All test operations successfully passed all asserts.";
      case FAIL:
        return "One or more test operations failed one or more asserts.";
      case PENDING:
        return "One or more test operations is pending execution completion.";
      case NULL:
        return null;
      default:
        return "?";
      }
    }

    public String getDisplay() {
      switch (this) {
      case PASS:
        return "Pass";
      case FAIL:
        return "Fail";
      case PENDING:
        return "Pending";
      case NULL:
        return null;
      default:
        return "?";
      }
    }
  }

  public static class TestReportResultEnumFactory implements EnumFactory {
    public TestReportResult fromCode(String codeString) throws IllegalArgumentException {
      if (codeString == null || "".equals(codeString))
        if (codeString == null || "".equals(codeString))
          return null;
      if ("pass".equals(codeString))
        return TestReportResult.PASS;
      if ("fail".equals(codeString))
        return TestReportResult.FAIL;
      if ("pending".equals(codeString))
        return TestReportResult.PENDING;
      throw new IllegalArgumentException("Unknown TestReportResult code '" + codeString + "'");
    }

    public Enumeration fromType(PrimitiveType code) throws FHIRException {
      if (code == null)
        return null;
      if (code.isEmpty())
        return new Enumeration(this, TestReportResult.NULL, code);
      String codeString = code.asStringValue();
      if (codeString == null || "".equals(codeString))
        return new Enumeration(this, TestReportResult.NULL, code);
      if ("pass".equals(codeString))
        return new Enumeration(this, TestReportResult.PASS, code);
      if ("fail".equals(codeString))
        return new Enumeration(this, TestReportResult.FAIL, code);
      if ("pending".equals(codeString))
        return new Enumeration(this, TestReportResult.PENDING, code);
      throw new FHIRException("Unknown TestReportResult code '" + codeString + "'");
    }

    public String toCode(TestReportResult code) {
      if (code == TestReportResult.PASS)
        return "pass";
      if (code == TestReportResult.FAIL)
        return "fail";
      if (code == TestReportResult.PENDING)
        return "pending";
      return "?";
    }

    public String toSystem(TestReportResult code) {
      return code.getSystem();
    }
  }

  public enum TestReportParticipantType {
    /**
     * The test execution engine.
     */
    TESTENGINE,
    /**
     * A FHIR Client.
     */
    CLIENT,
    /**
     * A FHIR Server.
     */
    SERVER,
    /**
     * added to help the parsers with the generic types
     */
    NULL;

    public static TestReportParticipantType fromCode(String codeString) throws FHIRException {
      if (codeString == null || "".equals(codeString))
        return null;
      if ("test-engine".equals(codeString))
        return TESTENGINE;
      if ("client".equals(codeString))
        return CLIENT;
      if ("server".equals(codeString))
        return SERVER;
      if (Configuration.isAcceptInvalidEnums())
        return null;
      else
        throw new FHIRException("Unknown TestReportParticipantType code '" + codeString + "'");
    }

    public String toCode() {
      switch (this) {
      case TESTENGINE:
        return "test-engine";
      case CLIENT:
        return "client";
      case SERVER:
        return "server";
      case NULL:
        return null;
      default:
        return "?";
      }
    }

    public String getSystem() {
      switch (this) {
      case TESTENGINE:
        return "http://hl7.org/fhir/report-participant-type";
      case CLIENT:
        return "http://hl7.org/fhir/report-participant-type";
      case SERVER:
        return "http://hl7.org/fhir/report-participant-type";
      case NULL:
        return null;
      default:
        return "?";
      }
    }

    public String getDefinition() {
      switch (this) {
      case TESTENGINE:
        return "The test execution engine.";
      case CLIENT:
        return "A FHIR Client.";
      case SERVER:
        return "A FHIR Server.";
      case NULL:
        return null;
      default:
        return "?";
      }
    }

    public String getDisplay() {
      switch (this) {
      case TESTENGINE:
        return "Test Engine";
      case CLIENT:
        return "Client";
      case SERVER:
        return "Server";
      case NULL:
        return null;
      default:
        return "?";
      }
    }
  }

  public static class TestReportParticipantTypeEnumFactory implements EnumFactory {
    public TestReportParticipantType fromCode(String codeString) throws IllegalArgumentException {
      if (codeString == null || "".equals(codeString))
        if (codeString == null || "".equals(codeString))
          return null;
      if ("test-engine".equals(codeString))
        return TestReportParticipantType.TESTENGINE;
      if ("client".equals(codeString))
        return TestReportParticipantType.CLIENT;
      if ("server".equals(codeString))
        return TestReportParticipantType.SERVER;
      throw new IllegalArgumentException("Unknown TestReportParticipantType code '" + codeString + "'");
    }

    public Enumeration fromType(PrimitiveType code) throws FHIRException {
      if (code == null)
        return null;
      if (code.isEmpty())
        return new Enumeration(this, TestReportParticipantType.NULL, code);
      String codeString = code.asStringValue();
      if (codeString == null || "".equals(codeString))
        return new Enumeration(this, TestReportParticipantType.NULL, code);
      if ("test-engine".equals(codeString))
        return new Enumeration(this, TestReportParticipantType.TESTENGINE, code);
      if ("client".equals(codeString))
        return new Enumeration(this, TestReportParticipantType.CLIENT, code);
      if ("server".equals(codeString))
        return new Enumeration(this, TestReportParticipantType.SERVER, code);
      throw new FHIRException("Unknown TestReportParticipantType code '" + codeString + "'");
    }

    public String toCode(TestReportParticipantType code) {
      if (code == TestReportParticipantType.TESTENGINE)
        return "test-engine";
      if (code == TestReportParticipantType.CLIENT)
        return "client";
      if (code == TestReportParticipantType.SERVER)
        return "server";
      return "?";
    }

    public String toSystem(TestReportParticipantType code) {
      return code.getSystem();
    }
  }

  public enum TestReportActionResult {
    /**
     * The action was successful.
     */
    PASS,
    /**
     * The action was skipped.
     */
    SKIP,
    /**
     * The action failed.
     */
    FAIL,
    /**
     * The action passed but with warnings.
     */
    WARNING,
    /**
     * The action encountered a fatal error and the engine was unable to process.
     */
    ERROR,
    /**
     * added to help the parsers with the generic types
     */
    NULL;

    public static TestReportActionResult fromCode(String codeString) throws FHIRException {
      if (codeString == null || "".equals(codeString))
        return null;
      if ("pass".equals(codeString))
        return PASS;
      if ("skip".equals(codeString))
        return SKIP;
      if ("fail".equals(codeString))
        return FAIL;
      if ("warning".equals(codeString))
        return WARNING;
      if ("error".equals(codeString))
        return ERROR;
      if (Configuration.isAcceptInvalidEnums())
        return null;
      else
        throw new FHIRException("Unknown TestReportActionResult code '" + codeString + "'");
    }

    public String toCode() {
      switch (this) {
      case PASS:
        return "pass";
      case SKIP:
        return "skip";
      case FAIL:
        return "fail";
      case WARNING:
        return "warning";
      case ERROR:
        return "error";
      case NULL:
        return null;
      default:
        return "?";
      }
    }

    public String getSystem() {
      switch (this) {
      case PASS:
        return "http://hl7.org/fhir/report-action-result-codes";
      case SKIP:
        return "http://hl7.org/fhir/report-action-result-codes";
      case FAIL:
        return "http://hl7.org/fhir/report-action-result-codes";
      case WARNING:
        return "http://hl7.org/fhir/report-action-result-codes";
      case ERROR:
        return "http://hl7.org/fhir/report-action-result-codes";
      case NULL:
        return null;
      default:
        return "?";
      }
    }

    public String getDefinition() {
      switch (this) {
      case PASS:
        return "The action was successful.";
      case SKIP:
        return "The action was skipped.";
      case FAIL:
        return "The action failed.";
      case WARNING:
        return "The action passed but with warnings.";
      case ERROR:
        return "The action encountered a fatal error and the engine was unable to process.";
      case NULL:
        return null;
      default:
        return "?";
      }
    }

    public String getDisplay() {
      switch (this) {
      case PASS:
        return "Pass";
      case SKIP:
        return "Skip";
      case FAIL:
        return "Fail";
      case WARNING:
        return "Warning";
      case ERROR:
        return "Error";
      case NULL:
        return null;
      default:
        return "?";
      }
    }
  }

  public static class TestReportActionResultEnumFactory implements EnumFactory {
    public TestReportActionResult fromCode(String codeString) throws IllegalArgumentException {
      if (codeString == null || "".equals(codeString))
        if (codeString == null || "".equals(codeString))
          return null;
      if ("pass".equals(codeString))
        return TestReportActionResult.PASS;
      if ("skip".equals(codeString))
        return TestReportActionResult.SKIP;
      if ("fail".equals(codeString))
        return TestReportActionResult.FAIL;
      if ("warning".equals(codeString))
        return TestReportActionResult.WARNING;
      if ("error".equals(codeString))
        return TestReportActionResult.ERROR;
      throw new IllegalArgumentException("Unknown TestReportActionResult code '" + codeString + "'");
    }

    public Enumeration fromType(PrimitiveType code) throws FHIRException {
      if (code == null)
        return null;
      if (code.isEmpty())
        return new Enumeration(this, TestReportActionResult.NULL, code);
      String codeString = code.asStringValue();
      if (codeString == null || "".equals(codeString))
        return new Enumeration(this, TestReportActionResult.NULL, code);
      if ("pass".equals(codeString))
        return new Enumeration(this, TestReportActionResult.PASS, code);
      if ("skip".equals(codeString))
        return new Enumeration(this, TestReportActionResult.SKIP, code);
      if ("fail".equals(codeString))
        return new Enumeration(this, TestReportActionResult.FAIL, code);
      if ("warning".equals(codeString))
        return new Enumeration(this, TestReportActionResult.WARNING, code);
      if ("error".equals(codeString))
        return new Enumeration(this, TestReportActionResult.ERROR, code);
      throw new FHIRException("Unknown TestReportActionResult code '" + codeString + "'");
    }

    public String toCode(TestReportActionResult code) {
      if (code == TestReportActionResult.PASS)
        return "pass";
      if (code == TestReportActionResult.SKIP)
        return "skip";
      if (code == TestReportActionResult.FAIL)
        return "fail";
      if (code == TestReportActionResult.WARNING)
        return "warning";
      if (code == TestReportActionResult.ERROR)
        return "error";
      return "?";
    }

    public String toSystem(TestReportActionResult code) {
      return code.getSystem();
    }
  }

  @Block()
  public static class TestReportParticipantComponent extends BackboneElement implements IBaseBackboneElement {
    /**
     * The type of participant.
     */
    @Child(name = "type", type = { CodeType.class }, order = 1, min = 1, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "test-engine | client | server", formalDefinition = "The type of participant.")
    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/report-participant-type")
    protected Enumeration type;

    /**
     * The uri of the participant. An absolute URL is preferred.
     */
    @Child(name = "uri", type = { UriType.class }, order = 2, min = 1, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "The uri of the participant. An absolute URL is preferred", formalDefinition = "The uri of the participant. An absolute URL is preferred.")
    protected UriType uri;

    /**
     * The display name of the participant.
     */
    @Child(name = "display", type = {
        StringType.class }, order = 3, min = 0, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "The display name of the participant", formalDefinition = "The display name of the participant.")
    protected StringType display;

    private static final long serialVersionUID = 577488357L;

    /**
     * Constructor
     */
    public TestReportParticipantComponent() {
      super();
    }

    /**
     * Constructor
     */
    public TestReportParticipantComponent(Enumeration type, UriType uri) {
      super();
      this.type = type;
      this.uri = uri;
    }

    /**
     * @return {@link #type} (The type of participant.). This is the underlying
     *         object with id, value and extensions. The accessor "getType" gives
     *         direct access to the value
     */
    public Enumeration getTypeElement() {
      if (this.type == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create TestReportParticipantComponent.type");
        else if (Configuration.doAutoCreate())
          this.type = new Enumeration(new TestReportParticipantTypeEnumFactory()); // bb
      return this.type;
    }

    public boolean hasTypeElement() {
      return this.type != null && !this.type.isEmpty();
    }

    public boolean hasType() {
      return this.type != null && !this.type.isEmpty();
    }

    /**
     * @param value {@link #type} (The type of participant.). This is the underlying
     *              object with id, value and extensions. The accessor "getType"
     *              gives direct access to the value
     */
    public TestReportParticipantComponent setTypeElement(Enumeration value) {
      this.type = value;
      return this;
    }

    /**
     * @return The type of participant.
     */
    public TestReportParticipantType getType() {
      return this.type == null ? null : this.type.getValue();
    }

    /**
     * @param value The type of participant.
     */
    public TestReportParticipantComponent setType(TestReportParticipantType value) {
      if (this.type == null)
        this.type = new Enumeration(new TestReportParticipantTypeEnumFactory());
      this.type.setValue(value);
      return this;
    }

    /**
     * @return {@link #uri} (The uri of the participant. An absolute URL is
     *         preferred.). This is the underlying object with id, value and
     *         extensions. The accessor "getUri" gives direct access to the value
     */
    public UriType getUriElement() {
      if (this.uri == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create TestReportParticipantComponent.uri");
        else if (Configuration.doAutoCreate())
          this.uri = new UriType(); // bb
      return this.uri;
    }

    public boolean hasUriElement() {
      return this.uri != null && !this.uri.isEmpty();
    }

    public boolean hasUri() {
      return this.uri != null && !this.uri.isEmpty();
    }

    /**
     * @param value {@link #uri} (The uri of the participant. An absolute URL is
     *              preferred.). This is the underlying object with id, value and
     *              extensions. The accessor "getUri" gives direct access to the
     *              value
     */
    public TestReportParticipantComponent setUriElement(UriType value) {
      this.uri = value;
      return this;
    }

    /**
     * @return The uri of the participant. An absolute URL is preferred.
     */
    public String getUri() {
      return this.uri == null ? null : this.uri.getValue();
    }

    /**
     * @param value The uri of the participant. An absolute URL is preferred.
     */
    public TestReportParticipantComponent setUri(String value) {
      if (this.uri == null)
        this.uri = new UriType();
      this.uri.setValue(value);
      return this;
    }

    /**
     * @return {@link #display} (The display name of the participant.). This is the
     *         underlying object with id, value and extensions. The accessor
     *         "getDisplay" gives direct access to the value
     */
    public StringType getDisplayElement() {
      if (this.display == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create TestReportParticipantComponent.display");
        else if (Configuration.doAutoCreate())
          this.display = new StringType(); // bb
      return this.display;
    }

    public boolean hasDisplayElement() {
      return this.display != null && !this.display.isEmpty();
    }

    public boolean hasDisplay() {
      return this.display != null && !this.display.isEmpty();
    }

    /**
     * @param value {@link #display} (The display name of the participant.). This is
     *              the underlying object with id, value and extensions. The
     *              accessor "getDisplay" gives direct access to the value
     */
    public TestReportParticipantComponent setDisplayElement(StringType value) {
      this.display = value;
      return this;
    }

    /**
     * @return The display name of the participant.
     */
    public String getDisplay() {
      return this.display == null ? null : this.display.getValue();
    }

    /**
     * @param value The display name of the participant.
     */
    public TestReportParticipantComponent setDisplay(String value) {
      if (Utilities.noString(value))
        this.display = null;
      else {
        if (this.display == null)
          this.display = new StringType();
        this.display.setValue(value);
      }
      return this;
    }

    protected void listChildren(List children) {
      super.listChildren(children);
      children.add(new Property("type", "code", "The type of participant.", 0, 1, type));
      children.add(new Property("uri", "uri", "The uri of the participant. An absolute URL is preferred.", 0, 1, uri));
      children.add(new Property("display", "string", "The display name of the participant.", 0, 1, display));
    }

    @Override
    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
      switch (_hash) {
      case 3575610:
        /* type */ return new Property("type", "code", "The type of participant.", 0, 1, type);
      case 116076:
        /* uri */ return new Property("uri", "uri", "The uri of the participant. An absolute URL is preferred.", 0, 1,
            uri);
      case 1671764162:
        /* display */ return new Property("display", "string", "The display name of the participant.", 0, 1, display);
      default:
        return super.getNamedProperty(_hash, _name, _checkValid);
      }

    }

    @Override
    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
      switch (hash) {
      case 3575610:
        /* type */ return this.type == null ? new Base[0] : new Base[] { this.type }; // Enumeration
      case 116076:
        /* uri */ return this.uri == null ? new Base[0] : new Base[] { this.uri }; // UriType
      case 1671764162:
        /* display */ return this.display == null ? new Base[0] : new Base[] { this.display }; // StringType
      default:
        return super.getProperty(hash, name, checkValid);
      }

    }

    @Override
    public Base setProperty(int hash, String name, Base value) throws FHIRException {
      switch (hash) {
      case 3575610: // type
        value = new TestReportParticipantTypeEnumFactory().fromType(castToCode(value));
        this.type = (Enumeration) value; // Enumeration
        return value;
      case 116076: // uri
        this.uri = castToUri(value); // UriType
        return value;
      case 1671764162: // display
        this.display = castToString(value); // StringType
        return value;
      default:
        return super.setProperty(hash, name, value);
      }

    }

    @Override
    public Base setProperty(String name, Base value) throws FHIRException {
      if (name.equals("type")) {
        value = new TestReportParticipantTypeEnumFactory().fromType(castToCode(value));
        this.type = (Enumeration) value; // Enumeration
      } else if (name.equals("uri")) {
        this.uri = castToUri(value); // UriType
      } else if (name.equals("display")) {
        this.display = castToString(value); // StringType
      } else
        return super.setProperty(name, value);
      return value;
    }

  @Override
  public void removeChild(String name, Base value) throws FHIRException {
      if (name.equals("type")) {
        this.type = null;
      } else if (name.equals("uri")) {
        this.uri = null;
      } else if (name.equals("display")) {
        this.display = null;
      } else
        super.removeChild(name, value);
      
    }

    @Override
    public Base makeProperty(int hash, String name) throws FHIRException {
      switch (hash) {
      case 3575610:
        return getTypeElement();
      case 116076:
        return getUriElement();
      case 1671764162:
        return getDisplayElement();
      default:
        return super.makeProperty(hash, name);
      }

    }

    @Override
    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
      switch (hash) {
      case 3575610:
        /* type */ return new String[] { "code" };
      case 116076:
        /* uri */ return new String[] { "uri" };
      case 1671764162:
        /* display */ return new String[] { "string" };
      default:
        return super.getTypesForProperty(hash, name);
      }

    }

    @Override
    public Base addChild(String name) throws FHIRException {
      if (name.equals("type")) {
        throw new FHIRException("Cannot call addChild on a singleton property TestReport.type");
      } else if (name.equals("uri")) {
        throw new FHIRException("Cannot call addChild on a singleton property TestReport.uri");
      } else if (name.equals("display")) {
        throw new FHIRException("Cannot call addChild on a singleton property TestReport.display");
      } else
        return super.addChild(name);
    }

    public TestReportParticipantComponent copy() {
      TestReportParticipantComponent dst = new TestReportParticipantComponent();
      copyValues(dst);
      return dst;
    }

    public void copyValues(TestReportParticipantComponent dst) {
      super.copyValues(dst);
      dst.type = type == null ? null : type.copy();
      dst.uri = uri == null ? null : uri.copy();
      dst.display = display == null ? null : display.copy();
    }

    @Override
    public boolean equalsDeep(Base other_) {
      if (!super.equalsDeep(other_))
        return false;
      if (!(other_ instanceof TestReportParticipantComponent))
        return false;
      TestReportParticipantComponent o = (TestReportParticipantComponent) other_;
      return compareDeep(type, o.type, true) && compareDeep(uri, o.uri, true) && compareDeep(display, o.display, true);
    }

    @Override
    public boolean equalsShallow(Base other_) {
      if (!super.equalsShallow(other_))
        return false;
      if (!(other_ instanceof TestReportParticipantComponent))
        return false;
      TestReportParticipantComponent o = (TestReportParticipantComponent) other_;
      return compareValues(type, o.type, true) && compareValues(uri, o.uri, true)
          && compareValues(display, o.display, true);
    }

    public boolean isEmpty() {
      return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(type, uri, display);
    }

    public String fhirType() {
      return "TestReport.participant";

    }

  }

  @Block()
  public static class TestReportSetupComponent extends BackboneElement implements IBaseBackboneElement {
    /**
     * Action would contain either an operation or an assertion.
     */
    @Child(name = "action", type = {}, order = 1, min = 1, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
    @Description(shortDefinition = "A setup operation or assert that was executed", formalDefinition = "Action would contain either an operation or an assertion.")
    protected List action;

    private static final long serialVersionUID = -123374486L;

    /**
     * Constructor
     */
    public TestReportSetupComponent() {
      super();
    }

    /**
     * @return {@link #action} (Action would contain either an operation or an
     *         assertion.)
     */
    public List getAction() {
      if (this.action == null)
        this.action = new ArrayList();
      return this.action;
    }

    /**
     * @return Returns a reference to this for easy method chaining
     */
    public TestReportSetupComponent setAction(List theAction) {
      this.action = theAction;
      return this;
    }

    public boolean hasAction() {
      if (this.action == null)
        return false;
      for (SetupActionComponent item : this.action)
        if (!item.isEmpty())
          return true;
      return false;
    }

    public SetupActionComponent addAction() { // 3
      SetupActionComponent t = new SetupActionComponent();
      if (this.action == null)
        this.action = new ArrayList();
      this.action.add(t);
      return t;
    }

    public TestReportSetupComponent addAction(SetupActionComponent t) { // 3
      if (t == null)
        return this;
      if (this.action == null)
        this.action = new ArrayList();
      this.action.add(t);
      return this;
    }

    /**
     * @return The first repetition of repeating field {@link #action}, creating it
     *         if it does not already exist
     */
    public SetupActionComponent getActionFirstRep() {
      if (getAction().isEmpty()) {
        addAction();
      }
      return getAction().get(0);
    }

    protected void listChildren(List children) {
      super.listChildren(children);
      children.add(new Property("action", "", "Action would contain either an operation or an assertion.", 0,
          java.lang.Integer.MAX_VALUE, action));
    }

    @Override
    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
      switch (_hash) {
      case -1422950858:
        /* action */ return new Property("action", "", "Action would contain either an operation or an assertion.", 0,
            java.lang.Integer.MAX_VALUE, action);
      default:
        return super.getNamedProperty(_hash, _name, _checkValid);
      }

    }

    @Override
    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
      switch (hash) {
      case -1422950858:
        /* action */ return this.action == null ? new Base[0] : this.action.toArray(new Base[this.action.size()]); // SetupActionComponent
      default:
        return super.getProperty(hash, name, checkValid);
      }

    }

    @Override
    public Base setProperty(int hash, String name, Base value) throws FHIRException {
      switch (hash) {
      case -1422950858: // action
        this.getAction().add((SetupActionComponent) value); // SetupActionComponent
        return value;
      default:
        return super.setProperty(hash, name, value);
      }

    }

    @Override
    public Base setProperty(String name, Base value) throws FHIRException {
      if (name.equals("action")) {
        this.getAction().add((SetupActionComponent) value);
      } else
        return super.setProperty(name, value);
      return value;
    }

  @Override
  public void removeChild(String name, Base value) throws FHIRException {
      if (name.equals("action")) {
        this.getAction().remove((SetupActionComponent) value);
      } else
        super.removeChild(name, value);
      
    }

    @Override
    public Base makeProperty(int hash, String name) throws FHIRException {
      switch (hash) {
      case -1422950858:
        return addAction();
      default:
        return super.makeProperty(hash, name);
      }

    }

    @Override
    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
      switch (hash) {
      case -1422950858:
        /* action */ return new String[] {};
      default:
        return super.getTypesForProperty(hash, name);
      }

    }

    @Override
    public Base addChild(String name) throws FHIRException {
      if (name.equals("action")) {
        return addAction();
      } else
        return super.addChild(name);
    }

    public TestReportSetupComponent copy() {
      TestReportSetupComponent dst = new TestReportSetupComponent();
      copyValues(dst);
      return dst;
    }

    public void copyValues(TestReportSetupComponent dst) {
      super.copyValues(dst);
      if (action != null) {
        dst.action = new ArrayList();
        for (SetupActionComponent i : action)
          dst.action.add(i.copy());
      }
      ;
    }

    @Override
    public boolean equalsDeep(Base other_) {
      if (!super.equalsDeep(other_))
        return false;
      if (!(other_ instanceof TestReportSetupComponent))
        return false;
      TestReportSetupComponent o = (TestReportSetupComponent) other_;
      return compareDeep(action, o.action, true);
    }

    @Override
    public boolean equalsShallow(Base other_) {
      if (!super.equalsShallow(other_))
        return false;
      if (!(other_ instanceof TestReportSetupComponent))
        return false;
      TestReportSetupComponent o = (TestReportSetupComponent) other_;
      return true;
    }

    public boolean isEmpty() {
      return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(action);
    }

    public String fhirType() {
      return "TestReport.setup";

    }

  }

  @Block()
  public static class SetupActionComponent extends BackboneElement implements IBaseBackboneElement {
    /**
     * The operation performed.
     */
    @Child(name = "operation", type = {}, order = 1, min = 0, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "The operation to perform", formalDefinition = "The operation performed.")
    protected SetupActionOperationComponent operation;

    /**
     * The results of the assertion performed on the previous operations.
     */
    @Child(name = "assert", type = {}, order = 2, min = 0, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "The assertion to perform", formalDefinition = "The results of the assertion performed on the previous operations.")
    protected SetupActionAssertComponent assert_;

    private static final long serialVersionUID = -252088305L;

    /**
     * Constructor
     */
    public SetupActionComponent() {
      super();
    }

    /**
     * @return {@link #operation} (The operation performed.)
     */
    public SetupActionOperationComponent getOperation() {
      if (this.operation == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create SetupActionComponent.operation");
        else if (Configuration.doAutoCreate())
          this.operation = new SetupActionOperationComponent(); // cc
      return this.operation;
    }

    public boolean hasOperation() {
      return this.operation != null && !this.operation.isEmpty();
    }

    /**
     * @param value {@link #operation} (The operation performed.)
     */
    public SetupActionComponent setOperation(SetupActionOperationComponent value) {
      this.operation = value;
      return this;
    }

    /**
     * @return {@link #assert_} (The results of the assertion performed on the
     *         previous operations.)
     */
    public SetupActionAssertComponent getAssert() {
      if (this.assert_ == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create SetupActionComponent.assert_");
        else if (Configuration.doAutoCreate())
          this.assert_ = new SetupActionAssertComponent(); // cc
      return this.assert_;
    }

    public boolean hasAssert() {
      return this.assert_ != null && !this.assert_.isEmpty();
    }

    /**
     * @param value {@link #assert_} (The results of the assertion performed on the
     *              previous operations.)
     */
    public SetupActionComponent setAssert(SetupActionAssertComponent value) {
      this.assert_ = value;
      return this;
    }

    protected void listChildren(List children) {
      super.listChildren(children);
      children.add(new Property("operation", "", "The operation performed.", 0, 1, operation));
      children.add(new Property("assert", "", "The results of the assertion performed on the previous operations.", 0,
          1, assert_));
    }

    @Override
    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
      switch (_hash) {
      case 1662702951:
        /* operation */ return new Property("operation", "", "The operation performed.", 0, 1, operation);
      case -1408208058:
        /* assert */ return new Property("assert", "",
            "The results of the assertion performed on the previous operations.", 0, 1, assert_);
      default:
        return super.getNamedProperty(_hash, _name, _checkValid);
      }

    }

    @Override
    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
      switch (hash) {
      case 1662702951:
        /* operation */ return this.operation == null ? new Base[0] : new Base[] { this.operation }; // SetupActionOperationComponent
      case -1408208058:
        /* assert */ return this.assert_ == null ? new Base[0] : new Base[] { this.assert_ }; // SetupActionAssertComponent
      default:
        return super.getProperty(hash, name, checkValid);
      }

    }

    @Override
    public Base setProperty(int hash, String name, Base value) throws FHIRException {
      switch (hash) {
      case 1662702951: // operation
        this.operation = (SetupActionOperationComponent) value; // SetupActionOperationComponent
        return value;
      case -1408208058: // assert
        this.assert_ = (SetupActionAssertComponent) value; // SetupActionAssertComponent
        return value;
      default:
        return super.setProperty(hash, name, value);
      }

    }

    @Override
    public Base setProperty(String name, Base value) throws FHIRException {
      if (name.equals("operation")) {
        this.operation = (SetupActionOperationComponent) value; // SetupActionOperationComponent
      } else if (name.equals("assert")) {
        this.assert_ = (SetupActionAssertComponent) value; // SetupActionAssertComponent
      } else
        return super.setProperty(name, value);
      return value;
    }

  @Override
  public void removeChild(String name, Base value) throws FHIRException {
      if (name.equals("operation")) {
        this.operation = (SetupActionOperationComponent) value; // SetupActionOperationComponent
      } else if (name.equals("assert")) {
        this.assert_ = (SetupActionAssertComponent) value; // SetupActionAssertComponent
      } else
        super.removeChild(name, value);
      
    }

    @Override
    public Base makeProperty(int hash, String name) throws FHIRException {
      switch (hash) {
      case 1662702951:
        return getOperation();
      case -1408208058:
        return getAssert();
      default:
        return super.makeProperty(hash, name);
      }

    }

    @Override
    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
      switch (hash) {
      case 1662702951:
        /* operation */ return new String[] {};
      case -1408208058:
        /* assert */ return new String[] {};
      default:
        return super.getTypesForProperty(hash, name);
      }

    }

    @Override
    public Base addChild(String name) throws FHIRException {
      if (name.equals("operation")) {
        this.operation = new SetupActionOperationComponent();
        return this.operation;
      } else if (name.equals("assert")) {
        this.assert_ = new SetupActionAssertComponent();
        return this.assert_;
      } else
        return super.addChild(name);
    }

    public SetupActionComponent copy() {
      SetupActionComponent dst = new SetupActionComponent();
      copyValues(dst);
      return dst;
    }

    public void copyValues(SetupActionComponent dst) {
      super.copyValues(dst);
      dst.operation = operation == null ? null : operation.copy();
      dst.assert_ = assert_ == null ? null : assert_.copy();
    }

    @Override
    public boolean equalsDeep(Base other_) {
      if (!super.equalsDeep(other_))
        return false;
      if (!(other_ instanceof SetupActionComponent))
        return false;
      SetupActionComponent o = (SetupActionComponent) other_;
      return compareDeep(operation, o.operation, true) && compareDeep(assert_, o.assert_, true);
    }

    @Override
    public boolean equalsShallow(Base other_) {
      if (!super.equalsShallow(other_))
        return false;
      if (!(other_ instanceof SetupActionComponent))
        return false;
      SetupActionComponent o = (SetupActionComponent) other_;
      return true;
    }

    public boolean isEmpty() {
      return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(operation, assert_);
    }

    public String fhirType() {
      return "TestReport.setup.action";

    }

  }

  @Block()
  public static class SetupActionOperationComponent extends BackboneElement implements IBaseBackboneElement {
    /**
     * The result of this operation.
     */
    @Child(name = "result", type = { CodeType.class }, order = 1, min = 1, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "pass | skip | fail | warning | error", formalDefinition = "The result of this operation.")
    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/report-action-result-codes")
    protected Enumeration result;

    /**
     * An explanatory message associated with the result.
     */
    @Child(name = "message", type = {
        MarkdownType.class }, order = 2, min = 0, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "A message associated with the result", formalDefinition = "An explanatory message associated with the result.")
    protected MarkdownType message;

    /**
     * A link to further details on the result.
     */
    @Child(name = "detail", type = { UriType.class }, order = 3, min = 0, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "A link to further details on the result", formalDefinition = "A link to further details on the result.")
    protected UriType detail;

    private static final long serialVersionUID = 269088798L;

    /**
     * Constructor
     */
    public SetupActionOperationComponent() {
      super();
    }

    /**
     * Constructor
     */
    public SetupActionOperationComponent(Enumeration result) {
      super();
      this.result = result;
    }

    /**
     * @return {@link #result} (The result of this operation.). This is the
     *         underlying object with id, value and extensions. The accessor
     *         "getResult" gives direct access to the value
     */
    public Enumeration getResultElement() {
      if (this.result == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create SetupActionOperationComponent.result");
        else if (Configuration.doAutoCreate())
          this.result = new Enumeration(new TestReportActionResultEnumFactory()); // bb
      return this.result;
    }

    public boolean hasResultElement() {
      return this.result != null && !this.result.isEmpty();
    }

    public boolean hasResult() {
      return this.result != null && !this.result.isEmpty();
    }

    /**
     * @param value {@link #result} (The result of this operation.). This is the
     *              underlying object with id, value and extensions. The accessor
     *              "getResult" gives direct access to the value
     */
    public SetupActionOperationComponent setResultElement(Enumeration value) {
      this.result = value;
      return this;
    }

    /**
     * @return The result of this operation.
     */
    public TestReportActionResult getResult() {
      return this.result == null ? null : this.result.getValue();
    }

    /**
     * @param value The result of this operation.
     */
    public SetupActionOperationComponent setResult(TestReportActionResult value) {
      if (this.result == null)
        this.result = new Enumeration(new TestReportActionResultEnumFactory());
      this.result.setValue(value);
      return this;
    }

    /**
     * @return {@link #message} (An explanatory message associated with the
     *         result.). This is the underlying object with id, value and
     *         extensions. The accessor "getMessage" gives direct access to the
     *         value
     */
    public MarkdownType getMessageElement() {
      if (this.message == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create SetupActionOperationComponent.message");
        else if (Configuration.doAutoCreate())
          this.message = new MarkdownType(); // bb
      return this.message;
    }

    public boolean hasMessageElement() {
      return this.message != null && !this.message.isEmpty();
    }

    public boolean hasMessage() {
      return this.message != null && !this.message.isEmpty();
    }

    /**
     * @param value {@link #message} (An explanatory message associated with the
     *              result.). This is the underlying object with id, value and
     *              extensions. The accessor "getMessage" gives direct access to the
     *              value
     */
    public SetupActionOperationComponent setMessageElement(MarkdownType value) {
      this.message = value;
      return this;
    }

    /**
     * @return An explanatory message associated with the result.
     */
    public String getMessage() {
      return this.message == null ? null : this.message.getValue();
    }

    /**
     * @param value An explanatory message associated with the result.
     */
    public SetupActionOperationComponent setMessage(String value) {
      if (value == null)
        this.message = null;
      else {
        if (this.message == null)
          this.message = new MarkdownType();
        this.message.setValue(value);
      }
      return this;
    }

    /**
     * @return {@link #detail} (A link to further details on the result.). This is
     *         the underlying object with id, value and extensions. The accessor
     *         "getDetail" gives direct access to the value
     */
    public UriType getDetailElement() {
      if (this.detail == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create SetupActionOperationComponent.detail");
        else if (Configuration.doAutoCreate())
          this.detail = new UriType(); // bb
      return this.detail;
    }

    public boolean hasDetailElement() {
      return this.detail != null && !this.detail.isEmpty();
    }

    public boolean hasDetail() {
      return this.detail != null && !this.detail.isEmpty();
    }

    /**
     * @param value {@link #detail} (A link to further details on the result.). This
     *              is the underlying object with id, value and extensions. The
     *              accessor "getDetail" gives direct access to the value
     */
    public SetupActionOperationComponent setDetailElement(UriType value) {
      this.detail = value;
      return this;
    }

    /**
     * @return A link to further details on the result.
     */
    public String getDetail() {
      return this.detail == null ? null : this.detail.getValue();
    }

    /**
     * @param value A link to further details on the result.
     */
    public SetupActionOperationComponent setDetail(String value) {
      if (Utilities.noString(value))
        this.detail = null;
      else {
        if (this.detail == null)
          this.detail = new UriType();
        this.detail.setValue(value);
      }
      return this;
    }

    protected void listChildren(List children) {
      super.listChildren(children);
      children.add(new Property("result", "code", "The result of this operation.", 0, 1, result));
      children.add(
          new Property("message", "markdown", "An explanatory message associated with the result.", 0, 1, message));
      children.add(new Property("detail", "uri", "A link to further details on the result.", 0, 1, detail));
    }

    @Override
    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
      switch (_hash) {
      case -934426595:
        /* result */ return new Property("result", "code", "The result of this operation.", 0, 1, result);
      case 954925063:
        /* message */ return new Property("message", "markdown", "An explanatory message associated with the result.",
            0, 1, message);
      case -1335224239:
        /* detail */ return new Property("detail", "uri", "A link to further details on the result.", 0, 1, detail);
      default:
        return super.getNamedProperty(_hash, _name, _checkValid);
      }

    }

    @Override
    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
      switch (hash) {
      case -934426595:
        /* result */ return this.result == null ? new Base[0] : new Base[] { this.result }; // Enumeration
      case 954925063:
        /* message */ return this.message == null ? new Base[0] : new Base[] { this.message }; // MarkdownType
      case -1335224239:
        /* detail */ return this.detail == null ? new Base[0] : new Base[] { this.detail }; // UriType
      default:
        return super.getProperty(hash, name, checkValid);
      }

    }

    @Override
    public Base setProperty(int hash, String name, Base value) throws FHIRException {
      switch (hash) {
      case -934426595: // result
        value = new TestReportActionResultEnumFactory().fromType(castToCode(value));
        this.result = (Enumeration) value; // Enumeration
        return value;
      case 954925063: // message
        this.message = castToMarkdown(value); // MarkdownType
        return value;
      case -1335224239: // detail
        this.detail = castToUri(value); // UriType
        return value;
      default:
        return super.setProperty(hash, name, value);
      }

    }

    @Override
    public Base setProperty(String name, Base value) throws FHIRException {
      if (name.equals("result")) {
        value = new TestReportActionResultEnumFactory().fromType(castToCode(value));
        this.result = (Enumeration) value; // Enumeration
      } else if (name.equals("message")) {
        this.message = castToMarkdown(value); // MarkdownType
      } else if (name.equals("detail")) {
        this.detail = castToUri(value); // UriType
      } else
        return super.setProperty(name, value);
      return value;
    }

  @Override
  public void removeChild(String name, Base value) throws FHIRException {
      if (name.equals("result")) {
        this.result = null;
      } else if (name.equals("message")) {
        this.message = null;
      } else if (name.equals("detail")) {
        this.detail = null;
      } else
        super.removeChild(name, value);
      
    }

    @Override
    public Base makeProperty(int hash, String name) throws FHIRException {
      switch (hash) {
      case -934426595:
        return getResultElement();
      case 954925063:
        return getMessageElement();
      case -1335224239:
        return getDetailElement();
      default:
        return super.makeProperty(hash, name);
      }

    }

    @Override
    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
      switch (hash) {
      case -934426595:
        /* result */ return new String[] { "code" };
      case 954925063:
        /* message */ return new String[] { "markdown" };
      case -1335224239:
        /* detail */ return new String[] { "uri" };
      default:
        return super.getTypesForProperty(hash, name);
      }

    }

    @Override
    public Base addChild(String name) throws FHIRException {
      if (name.equals("result")) {
        throw new FHIRException("Cannot call addChild on a singleton property TestReport.result");
      } else if (name.equals("message")) {
        throw new FHIRException("Cannot call addChild on a singleton property TestReport.message");
      } else if (name.equals("detail")) {
        throw new FHIRException("Cannot call addChild on a singleton property TestReport.detail");
      } else
        return super.addChild(name);
    }

    public SetupActionOperationComponent copy() {
      SetupActionOperationComponent dst = new SetupActionOperationComponent();
      copyValues(dst);
      return dst;
    }

    public void copyValues(SetupActionOperationComponent dst) {
      super.copyValues(dst);
      dst.result = result == null ? null : result.copy();
      dst.message = message == null ? null : message.copy();
      dst.detail = detail == null ? null : detail.copy();
    }

    @Override
    public boolean equalsDeep(Base other_) {
      if (!super.equalsDeep(other_))
        return false;
      if (!(other_ instanceof SetupActionOperationComponent))
        return false;
      SetupActionOperationComponent o = (SetupActionOperationComponent) other_;
      return compareDeep(result, o.result, true) && compareDeep(message, o.message, true)
          && compareDeep(detail, o.detail, true);
    }

    @Override
    public boolean equalsShallow(Base other_) {
      if (!super.equalsShallow(other_))
        return false;
      if (!(other_ instanceof SetupActionOperationComponent))
        return false;
      SetupActionOperationComponent o = (SetupActionOperationComponent) other_;
      return compareValues(result, o.result, true) && compareValues(message, o.message, true)
          && compareValues(detail, o.detail, true);
    }

    public boolean isEmpty() {
      return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(result, message, detail);
    }

    public String fhirType() {
      return "TestReport.setup.action.operation";

    }

  }

  @Block()
  public static class SetupActionAssertComponent extends BackboneElement implements IBaseBackboneElement {
    /**
     * The result of this assertion.
     */
    @Child(name = "result", type = { CodeType.class }, order = 1, min = 1, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "pass | skip | fail | warning | error", formalDefinition = "The result of this assertion.")
    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/report-action-result-codes")
    protected Enumeration result;

    /**
     * An explanatory message associated with the result.
     */
    @Child(name = "message", type = {
        MarkdownType.class }, order = 2, min = 0, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "A message associated with the result", formalDefinition = "An explanatory message associated with the result.")
    protected MarkdownType message;

    /**
     * A link to further details on the result.
     */
    @Child(name = "detail", type = { StringType.class }, order = 3, min = 0, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "A link to further details on the result", formalDefinition = "A link to further details on the result.")
    protected StringType detail;

    private static final long serialVersionUID = 467968193L;

    /**
     * Constructor
     */
    public SetupActionAssertComponent() {
      super();
    }

    /**
     * Constructor
     */
    public SetupActionAssertComponent(Enumeration result) {
      super();
      this.result = result;
    }

    /**
     * @return {@link #result} (The result of this assertion.). This is the
     *         underlying object with id, value and extensions. The accessor
     *         "getResult" gives direct access to the value
     */
    public Enumeration getResultElement() {
      if (this.result == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create SetupActionAssertComponent.result");
        else if (Configuration.doAutoCreate())
          this.result = new Enumeration(new TestReportActionResultEnumFactory()); // bb
      return this.result;
    }

    public boolean hasResultElement() {
      return this.result != null && !this.result.isEmpty();
    }

    public boolean hasResult() {
      return this.result != null && !this.result.isEmpty();
    }

    /**
     * @param value {@link #result} (The result of this assertion.). This is the
     *              underlying object with id, value and extensions. The accessor
     *              "getResult" gives direct access to the value
     */
    public SetupActionAssertComponent setResultElement(Enumeration value) {
      this.result = value;
      return this;
    }

    /**
     * @return The result of this assertion.
     */
    public TestReportActionResult getResult() {
      return this.result == null ? null : this.result.getValue();
    }

    /**
     * @param value The result of this assertion.
     */
    public SetupActionAssertComponent setResult(TestReportActionResult value) {
      if (this.result == null)
        this.result = new Enumeration(new TestReportActionResultEnumFactory());
      this.result.setValue(value);
      return this;
    }

    /**
     * @return {@link #message} (An explanatory message associated with the
     *         result.). This is the underlying object with id, value and
     *         extensions. The accessor "getMessage" gives direct access to the
     *         value
     */
    public MarkdownType getMessageElement() {
      if (this.message == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create SetupActionAssertComponent.message");
        else if (Configuration.doAutoCreate())
          this.message = new MarkdownType(); // bb
      return this.message;
    }

    public boolean hasMessageElement() {
      return this.message != null && !this.message.isEmpty();
    }

    public boolean hasMessage() {
      return this.message != null && !this.message.isEmpty();
    }

    /**
     * @param value {@link #message} (An explanatory message associated with the
     *              result.). This is the underlying object with id, value and
     *              extensions. The accessor "getMessage" gives direct access to the
     *              value
     */
    public SetupActionAssertComponent setMessageElement(MarkdownType value) {
      this.message = value;
      return this;
    }

    /**
     * @return An explanatory message associated with the result.
     */
    public String getMessage() {
      return this.message == null ? null : this.message.getValue();
    }

    /**
     * @param value An explanatory message associated with the result.
     */
    public SetupActionAssertComponent setMessage(String value) {
      if (value == null)
        this.message = null;
      else {
        if (this.message == null)
          this.message = new MarkdownType();
        this.message.setValue(value);
      }
      return this;
    }

    /**
     * @return {@link #detail} (A link to further details on the result.). This is
     *         the underlying object with id, value and extensions. The accessor
     *         "getDetail" gives direct access to the value
     */
    public StringType getDetailElement() {
      if (this.detail == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create SetupActionAssertComponent.detail");
        else if (Configuration.doAutoCreate())
          this.detail = new StringType(); // bb
      return this.detail;
    }

    public boolean hasDetailElement() {
      return this.detail != null && !this.detail.isEmpty();
    }

    public boolean hasDetail() {
      return this.detail != null && !this.detail.isEmpty();
    }

    /**
     * @param value {@link #detail} (A link to further details on the result.). This
     *              is the underlying object with id, value and extensions. The
     *              accessor "getDetail" gives direct access to the value
     */
    public SetupActionAssertComponent setDetailElement(StringType value) {
      this.detail = value;
      return this;
    }

    /**
     * @return A link to further details on the result.
     */
    public String getDetail() {
      return this.detail == null ? null : this.detail.getValue();
    }

    /**
     * @param value A link to further details on the result.
     */
    public SetupActionAssertComponent setDetail(String value) {
      if (Utilities.noString(value))
        this.detail = null;
      else {
        if (this.detail == null)
          this.detail = new StringType();
        this.detail.setValue(value);
      }
      return this;
    }

    protected void listChildren(List children) {
      super.listChildren(children);
      children.add(new Property("result", "code", "The result of this assertion.", 0, 1, result));
      children.add(
          new Property("message", "markdown", "An explanatory message associated with the result.", 0, 1, message));
      children.add(new Property("detail", "string", "A link to further details on the result.", 0, 1, detail));
    }

    @Override
    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
      switch (_hash) {
      case -934426595:
        /* result */ return new Property("result", "code", "The result of this assertion.", 0, 1, result);
      case 954925063:
        /* message */ return new Property("message", "markdown", "An explanatory message associated with the result.",
            0, 1, message);
      case -1335224239:
        /* detail */ return new Property("detail", "string", "A link to further details on the result.", 0, 1, detail);
      default:
        return super.getNamedProperty(_hash, _name, _checkValid);
      }

    }

    @Override
    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
      switch (hash) {
      case -934426595:
        /* result */ return this.result == null ? new Base[0] : new Base[] { this.result }; // Enumeration
      case 954925063:
        /* message */ return this.message == null ? new Base[0] : new Base[] { this.message }; // MarkdownType
      case -1335224239:
        /* detail */ return this.detail == null ? new Base[0] : new Base[] { this.detail }; // StringType
      default:
        return super.getProperty(hash, name, checkValid);
      }

    }

    @Override
    public Base setProperty(int hash, String name, Base value) throws FHIRException {
      switch (hash) {
      case -934426595: // result
        value = new TestReportActionResultEnumFactory().fromType(castToCode(value));
        this.result = (Enumeration) value; // Enumeration
        return value;
      case 954925063: // message
        this.message = castToMarkdown(value); // MarkdownType
        return value;
      case -1335224239: // detail
        this.detail = castToString(value); // StringType
        return value;
      default:
        return super.setProperty(hash, name, value);
      }

    }

    @Override
    public Base setProperty(String name, Base value) throws FHIRException {
      if (name.equals("result")) {
        value = new TestReportActionResultEnumFactory().fromType(castToCode(value));
        this.result = (Enumeration) value; // Enumeration
      } else if (name.equals("message")) {
        this.message = castToMarkdown(value); // MarkdownType
      } else if (name.equals("detail")) {
        this.detail = castToString(value); // StringType
      } else
        return super.setProperty(name, value);
      return value;
    }

  @Override
  public void removeChild(String name, Base value) throws FHIRException {
      if (name.equals("result")) {
        this.result = null;
      } else if (name.equals("message")) {
        this.message = null;
      } else if (name.equals("detail")) {
        this.detail = null;
      } else
        super.removeChild(name, value);
      
    }

    @Override
    public Base makeProperty(int hash, String name) throws FHIRException {
      switch (hash) {
      case -934426595:
        return getResultElement();
      case 954925063:
        return getMessageElement();
      case -1335224239:
        return getDetailElement();
      default:
        return super.makeProperty(hash, name);
      }

    }

    @Override
    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
      switch (hash) {
      case -934426595:
        /* result */ return new String[] { "code" };
      case 954925063:
        /* message */ return new String[] { "markdown" };
      case -1335224239:
        /* detail */ return new String[] { "string" };
      default:
        return super.getTypesForProperty(hash, name);
      }

    }

    @Override
    public Base addChild(String name) throws FHIRException {
      if (name.equals("result")) {
        throw new FHIRException("Cannot call addChild on a singleton property TestReport.result");
      } else if (name.equals("message")) {
        throw new FHIRException("Cannot call addChild on a singleton property TestReport.message");
      } else if (name.equals("detail")) {
        throw new FHIRException("Cannot call addChild on a singleton property TestReport.detail");
      } else
        return super.addChild(name);
    }

    public SetupActionAssertComponent copy() {
      SetupActionAssertComponent dst = new SetupActionAssertComponent();
      copyValues(dst);
      return dst;
    }

    public void copyValues(SetupActionAssertComponent dst) {
      super.copyValues(dst);
      dst.result = result == null ? null : result.copy();
      dst.message = message == null ? null : message.copy();
      dst.detail = detail == null ? null : detail.copy();
    }

    @Override
    public boolean equalsDeep(Base other_) {
      if (!super.equalsDeep(other_))
        return false;
      if (!(other_ instanceof SetupActionAssertComponent))
        return false;
      SetupActionAssertComponent o = (SetupActionAssertComponent) other_;
      return compareDeep(result, o.result, true) && compareDeep(message, o.message, true)
          && compareDeep(detail, o.detail, true);
    }

    @Override
    public boolean equalsShallow(Base other_) {
      if (!super.equalsShallow(other_))
        return false;
      if (!(other_ instanceof SetupActionAssertComponent))
        return false;
      SetupActionAssertComponent o = (SetupActionAssertComponent) other_;
      return compareValues(result, o.result, true) && compareValues(message, o.message, true)
          && compareValues(detail, o.detail, true);
    }

    public boolean isEmpty() {
      return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(result, message, detail);
    }

    public String fhirType() {
      return "TestReport.setup.action.assert";

    }

  }

  @Block()
  public static class TestReportTestComponent extends BackboneElement implements IBaseBackboneElement {
    /**
     * The name of this test used for tracking/logging purposes by test engines.
     */
    @Child(name = "name", type = { StringType.class }, order = 1, min = 0, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "Tracking/logging name of this test", formalDefinition = "The name of this test used for tracking/logging purposes by test engines.")
    protected StringType name;

    /**
     * A short description of the test used by test engines for tracking and
     * reporting purposes.
     */
    @Child(name = "description", type = {
        StringType.class }, order = 2, min = 0, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "Tracking/reporting short description of the test", formalDefinition = "A short description of the test used by test engines for tracking and reporting purposes.")
    protected StringType description;

    /**
     * Action would contain either an operation or an assertion.
     */
    @Child(name = "action", type = {}, order = 3, min = 1, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
    @Description(shortDefinition = "A test operation or assert that was performed", formalDefinition = "Action would contain either an operation or an assertion.")
    protected List action;

    private static final long serialVersionUID = -865006110L;

    /**
     * Constructor
     */
    public TestReportTestComponent() {
      super();
    }

    /**
     * @return {@link #name} (The name of this test used for tracking/logging
     *         purposes by test engines.). This is the underlying object with id,
     *         value and extensions. The accessor "getName" gives direct access to
     *         the value
     */
    public StringType getNameElement() {
      if (this.name == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create TestReportTestComponent.name");
        else if (Configuration.doAutoCreate())
          this.name = new StringType(); // bb
      return this.name;
    }

    public boolean hasNameElement() {
      return this.name != null && !this.name.isEmpty();
    }

    public boolean hasName() {
      return this.name != null && !this.name.isEmpty();
    }

    /**
     * @param value {@link #name} (The name of this test used for tracking/logging
     *              purposes by test engines.). This is the underlying object with
     *              id, value and extensions. The accessor "getName" gives direct
     *              access to the value
     */
    public TestReportTestComponent setNameElement(StringType value) {
      this.name = value;
      return this;
    }

    /**
     * @return The name of this test used for tracking/logging purposes by test
     *         engines.
     */
    public String getName() {
      return this.name == null ? null : this.name.getValue();
    }

    /**
     * @param value The name of this test used for tracking/logging purposes by test
     *              engines.
     */
    public TestReportTestComponent setName(String value) {
      if (Utilities.noString(value))
        this.name = null;
      else {
        if (this.name == null)
          this.name = new StringType();
        this.name.setValue(value);
      }
      return this;
    }

    /**
     * @return {@link #description} (A short description of the test used by test
     *         engines for tracking and reporting purposes.). This is the underlying
     *         object with id, value and extensions. The accessor "getDescription"
     *         gives direct access to the value
     */
    public StringType getDescriptionElement() {
      if (this.description == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create TestReportTestComponent.description");
        else if (Configuration.doAutoCreate())
          this.description = new StringType(); // bb
      return this.description;
    }

    public boolean hasDescriptionElement() {
      return this.description != null && !this.description.isEmpty();
    }

    public boolean hasDescription() {
      return this.description != null && !this.description.isEmpty();
    }

    /**
     * @param value {@link #description} (A short description of the test used by
     *              test engines for tracking and reporting purposes.). This is the
     *              underlying object with id, value and extensions. The accessor
     *              "getDescription" gives direct access to the value
     */
    public TestReportTestComponent setDescriptionElement(StringType value) {
      this.description = value;
      return this;
    }

    /**
     * @return A short description of the test used by test engines for tracking and
     *         reporting purposes.
     */
    public String getDescription() {
      return this.description == null ? null : this.description.getValue();
    }

    /**
     * @param value A short description of the test used by test engines for
     *              tracking and reporting purposes.
     */
    public TestReportTestComponent setDescription(String value) {
      if (Utilities.noString(value))
        this.description = null;
      else {
        if (this.description == null)
          this.description = new StringType();
        this.description.setValue(value);
      }
      return this;
    }

    /**
     * @return {@link #action} (Action would contain either an operation or an
     *         assertion.)
     */
    public List getAction() {
      if (this.action == null)
        this.action = new ArrayList();
      return this.action;
    }

    /**
     * @return Returns a reference to this for easy method chaining
     */
    public TestReportTestComponent setAction(List theAction) {
      this.action = theAction;
      return this;
    }

    public boolean hasAction() {
      if (this.action == null)
        return false;
      for (TestActionComponent item : this.action)
        if (!item.isEmpty())
          return true;
      return false;
    }

    public TestActionComponent addAction() { // 3
      TestActionComponent t = new TestActionComponent();
      if (this.action == null)
        this.action = new ArrayList();
      this.action.add(t);
      return t;
    }

    public TestReportTestComponent addAction(TestActionComponent t) { // 3
      if (t == null)
        return this;
      if (this.action == null)
        this.action = new ArrayList();
      this.action.add(t);
      return this;
    }

    /**
     * @return The first repetition of repeating field {@link #action}, creating it
     *         if it does not already exist
     */
    public TestActionComponent getActionFirstRep() {
      if (getAction().isEmpty()) {
        addAction();
      }
      return getAction().get(0);
    }

    protected void listChildren(List children) {
      super.listChildren(children);
      children.add(new Property("name", "string",
          "The name of this test used for tracking/logging purposes by test engines.", 0, 1, name));
      children.add(new Property("description", "string",
          "A short description of the test used by test engines for tracking and reporting purposes.", 0, 1,
          description));
      children.add(new Property("action", "", "Action would contain either an operation or an assertion.", 0,
          java.lang.Integer.MAX_VALUE, action));
    }

    @Override
    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
      switch (_hash) {
      case 3373707:
        /* name */ return new Property("name", "string",
            "The name of this test used for tracking/logging purposes by test engines.", 0, 1, name);
      case -1724546052:
        /* description */ return new Property("description", "string",
            "A short description of the test used by test engines for tracking and reporting purposes.", 0, 1,
            description);
      case -1422950858:
        /* action */ return new Property("action", "", "Action would contain either an operation or an assertion.", 0,
            java.lang.Integer.MAX_VALUE, action);
      default:
        return super.getNamedProperty(_hash, _name, _checkValid);
      }

    }

    @Override
    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
      switch (hash) {
      case 3373707:
        /* name */ return this.name == null ? new Base[0] : new Base[] { this.name }; // StringType
      case -1724546052:
        /* description */ return this.description == null ? new Base[0] : new Base[] { this.description }; // StringType
      case -1422950858:
        /* action */ return this.action == null ? new Base[0] : this.action.toArray(new Base[this.action.size()]); // TestActionComponent
      default:
        return super.getProperty(hash, name, checkValid);
      }

    }

    @Override
    public Base setProperty(int hash, String name, Base value) throws FHIRException {
      switch (hash) {
      case 3373707: // name
        this.name = castToString(value); // StringType
        return value;
      case -1724546052: // description
        this.description = castToString(value); // StringType
        return value;
      case -1422950858: // action
        this.getAction().add((TestActionComponent) value); // TestActionComponent
        return value;
      default:
        return super.setProperty(hash, name, value);
      }

    }

    @Override
    public Base setProperty(String name, Base value) throws FHIRException {
      if (name.equals("name")) {
        this.name = castToString(value); // StringType
      } else if (name.equals("description")) {
        this.description = castToString(value); // StringType
      } else if (name.equals("action")) {
        this.getAction().add((TestActionComponent) value);
      } else
        return super.setProperty(name, value);
      return value;
    }

  @Override
  public void removeChild(String name, Base value) throws FHIRException {
      if (name.equals("name")) {
        this.name = null;
      } else if (name.equals("description")) {
        this.description = null;
      } else if (name.equals("action")) {
        this.getAction().remove((TestActionComponent) value);
      } else
        super.removeChild(name, value);
      
    }

    @Override
    public Base makeProperty(int hash, String name) throws FHIRException {
      switch (hash) {
      case 3373707:
        return getNameElement();
      case -1724546052:
        return getDescriptionElement();
      case -1422950858:
        return addAction();
      default:
        return super.makeProperty(hash, name);
      }

    }

    @Override
    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
      switch (hash) {
      case 3373707:
        /* name */ return new String[] { "string" };
      case -1724546052:
        /* description */ return new String[] { "string" };
      case -1422950858:
        /* action */ return new String[] {};
      default:
        return super.getTypesForProperty(hash, name);
      }

    }

    @Override
    public Base addChild(String name) throws FHIRException {
      if (name.equals("name")) {
        throw new FHIRException("Cannot call addChild on a singleton property TestReport.name");
      } else if (name.equals("description")) {
        throw new FHIRException("Cannot call addChild on a singleton property TestReport.description");
      } else if (name.equals("action")) {
        return addAction();
      } else
        return super.addChild(name);
    }

    public TestReportTestComponent copy() {
      TestReportTestComponent dst = new TestReportTestComponent();
      copyValues(dst);
      return dst;
    }

    public void copyValues(TestReportTestComponent dst) {
      super.copyValues(dst);
      dst.name = name == null ? null : name.copy();
      dst.description = description == null ? null : description.copy();
      if (action != null) {
        dst.action = new ArrayList();
        for (TestActionComponent i : action)
          dst.action.add(i.copy());
      }
      ;
    }

    @Override
    public boolean equalsDeep(Base other_) {
      if (!super.equalsDeep(other_))
        return false;
      if (!(other_ instanceof TestReportTestComponent))
        return false;
      TestReportTestComponent o = (TestReportTestComponent) other_;
      return compareDeep(name, o.name, true) && compareDeep(description, o.description, true)
          && compareDeep(action, o.action, true);
    }

    @Override
    public boolean equalsShallow(Base other_) {
      if (!super.equalsShallow(other_))
        return false;
      if (!(other_ instanceof TestReportTestComponent))
        return false;
      TestReportTestComponent o = (TestReportTestComponent) other_;
      return compareValues(name, o.name, true) && compareValues(description, o.description, true);
    }

    public boolean isEmpty() {
      return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(name, description, action);
    }

    public String fhirType() {
      return "TestReport.test";

    }

  }

  @Block()
  public static class TestActionComponent extends BackboneElement implements IBaseBackboneElement {
    /**
     * An operation would involve a REST request to a server.
     */
    @Child(name = "operation", type = {
        SetupActionOperationComponent.class }, order = 1, min = 0, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "The operation performed", formalDefinition = "An operation would involve a REST request to a server.")
    protected SetupActionOperationComponent operation;

    /**
     * The results of the assertion performed on the previous operations.
     */
    @Child(name = "assert", type = {
        SetupActionAssertComponent.class }, order = 2, min = 0, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "The assertion performed", formalDefinition = "The results of the assertion performed on the previous operations.")
    protected SetupActionAssertComponent assert_;

    private static final long serialVersionUID = -252088305L;

    /**
     * Constructor
     */
    public TestActionComponent() {
      super();
    }

    /**
     * @return {@link #operation} (An operation would involve a REST request to a
     *         server.)
     */
    public SetupActionOperationComponent getOperation() {
      if (this.operation == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create TestActionComponent.operation");
        else if (Configuration.doAutoCreate())
          this.operation = new SetupActionOperationComponent(); // cc
      return this.operation;
    }

    public boolean hasOperation() {
      return this.operation != null && !this.operation.isEmpty();
    }

    /**
     * @param value {@link #operation} (An operation would involve a REST request to
     *              a server.)
     */
    public TestActionComponent setOperation(SetupActionOperationComponent value) {
      this.operation = value;
      return this;
    }

    /**
     * @return {@link #assert_} (The results of the assertion performed on the
     *         previous operations.)
     */
    public SetupActionAssertComponent getAssert() {
      if (this.assert_ == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create TestActionComponent.assert_");
        else if (Configuration.doAutoCreate())
          this.assert_ = new SetupActionAssertComponent(); // cc
      return this.assert_;
    }

    public boolean hasAssert() {
      return this.assert_ != null && !this.assert_.isEmpty();
    }

    /**
     * @param value {@link #assert_} (The results of the assertion performed on the
     *              previous operations.)
     */
    public TestActionComponent setAssert(SetupActionAssertComponent value) {
      this.assert_ = value;
      return this;
    }

    protected void listChildren(List children) {
      super.listChildren(children);
      children.add(new Property("operation", "@TestReport.setup.action.operation",
          "An operation would involve a REST request to a server.", 0, 1, operation));
      children.add(new Property("assert", "@TestReport.setup.action.assert",
          "The results of the assertion performed on the previous operations.", 0, 1, assert_));
    }

    @Override
    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
      switch (_hash) {
      case 1662702951:
        /* operation */ return new Property("operation", "@TestReport.setup.action.operation",
            "An operation would involve a REST request to a server.", 0, 1, operation);
      case -1408208058:
        /* assert */ return new Property("assert", "@TestReport.setup.action.assert",
            "The results of the assertion performed on the previous operations.", 0, 1, assert_);
      default:
        return super.getNamedProperty(_hash, _name, _checkValid);
      }

    }

    @Override
    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
      switch (hash) {
      case 1662702951:
        /* operation */ return this.operation == null ? new Base[0] : new Base[] { this.operation }; // SetupActionOperationComponent
      case -1408208058:
        /* assert */ return this.assert_ == null ? new Base[0] : new Base[] { this.assert_ }; // SetupActionAssertComponent
      default:
        return super.getProperty(hash, name, checkValid);
      }

    }

    @Override
    public Base setProperty(int hash, String name, Base value) throws FHIRException {
      switch (hash) {
      case 1662702951: // operation
        this.operation = (SetupActionOperationComponent) value; // SetupActionOperationComponent
        return value;
      case -1408208058: // assert
        this.assert_ = (SetupActionAssertComponent) value; // SetupActionAssertComponent
        return value;
      default:
        return super.setProperty(hash, name, value);
      }

    }

    @Override
    public Base setProperty(String name, Base value) throws FHIRException {
      if (name.equals("operation")) {
        this.operation = (SetupActionOperationComponent) value; // SetupActionOperationComponent
      } else if (name.equals("assert")) {
        this.assert_ = (SetupActionAssertComponent) value; // SetupActionAssertComponent
      } else
        return super.setProperty(name, value);
      return value;
    }

  @Override
  public void removeChild(String name, Base value) throws FHIRException {
      if (name.equals("operation")) {
        this.operation = (SetupActionOperationComponent) value; // SetupActionOperationComponent
      } else if (name.equals("assert")) {
        this.assert_ = (SetupActionAssertComponent) value; // SetupActionAssertComponent
      } else
        super.removeChild(name, value);
      
    }

    @Override
    public Base makeProperty(int hash, String name) throws FHIRException {
      switch (hash) {
      case 1662702951:
        return getOperation();
      case -1408208058:
        return getAssert();
      default:
        return super.makeProperty(hash, name);
      }

    }

    @Override
    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
      switch (hash) {
      case 1662702951:
        /* operation */ return new String[] { "@TestReport.setup.action.operation" };
      case -1408208058:
        /* assert */ return new String[] { "@TestReport.setup.action.assert" };
      default:
        return super.getTypesForProperty(hash, name);
      }

    }

    @Override
    public Base addChild(String name) throws FHIRException {
      if (name.equals("operation")) {
        this.operation = new SetupActionOperationComponent();
        return this.operation;
      } else if (name.equals("assert")) {
        this.assert_ = new SetupActionAssertComponent();
        return this.assert_;
      } else
        return super.addChild(name);
    }

    public TestActionComponent copy() {
      TestActionComponent dst = new TestActionComponent();
      copyValues(dst);
      return dst;
    }

    public void copyValues(TestActionComponent dst) {
      super.copyValues(dst);
      dst.operation = operation == null ? null : operation.copy();
      dst.assert_ = assert_ == null ? null : assert_.copy();
    }

    @Override
    public boolean equalsDeep(Base other_) {
      if (!super.equalsDeep(other_))
        return false;
      if (!(other_ instanceof TestActionComponent))
        return false;
      TestActionComponent o = (TestActionComponent) other_;
      return compareDeep(operation, o.operation, true) && compareDeep(assert_, o.assert_, true);
    }

    @Override
    public boolean equalsShallow(Base other_) {
      if (!super.equalsShallow(other_))
        return false;
      if (!(other_ instanceof TestActionComponent))
        return false;
      TestActionComponent o = (TestActionComponent) other_;
      return true;
    }

    public boolean isEmpty() {
      return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(operation, assert_);
    }

    public String fhirType() {
      return "TestReport.test.action";

    }

  }

  @Block()
  public static class TestReportTeardownComponent extends BackboneElement implements IBaseBackboneElement {
    /**
     * The teardown action will only contain an operation.
     */
    @Child(name = "action", type = {}, order = 1, min = 1, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
    @Description(shortDefinition = "One or more teardown operations performed", formalDefinition = "The teardown action will only contain an operation.")
    protected List action;

    private static final long serialVersionUID = 1168638089L;

    /**
     * Constructor
     */
    public TestReportTeardownComponent() {
      super();
    }

    /**
     * @return {@link #action} (The teardown action will only contain an operation.)
     */
    public List getAction() {
      if (this.action == null)
        this.action = new ArrayList();
      return this.action;
    }

    /**
     * @return Returns a reference to this for easy method chaining
     */
    public TestReportTeardownComponent setAction(List theAction) {
      this.action = theAction;
      return this;
    }

    public boolean hasAction() {
      if (this.action == null)
        return false;
      for (TeardownActionComponent item : this.action)
        if (!item.isEmpty())
          return true;
      return false;
    }

    public TeardownActionComponent addAction() { // 3
      TeardownActionComponent t = new TeardownActionComponent();
      if (this.action == null)
        this.action = new ArrayList();
      this.action.add(t);
      return t;
    }

    public TestReportTeardownComponent addAction(TeardownActionComponent t) { // 3
      if (t == null)
        return this;
      if (this.action == null)
        this.action = new ArrayList();
      this.action.add(t);
      return this;
    }

    /**
     * @return The first repetition of repeating field {@link #action}, creating it
     *         if it does not already exist
     */
    public TeardownActionComponent getActionFirstRep() {
      if (getAction().isEmpty()) {
        addAction();
      }
      return getAction().get(0);
    }

    protected void listChildren(List children) {
      super.listChildren(children);
      children.add(new Property("action", "", "The teardown action will only contain an operation.", 0,
          java.lang.Integer.MAX_VALUE, action));
    }

    @Override
    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
      switch (_hash) {
      case -1422950858:
        /* action */ return new Property("action", "", "The teardown action will only contain an operation.", 0,
            java.lang.Integer.MAX_VALUE, action);
      default:
        return super.getNamedProperty(_hash, _name, _checkValid);
      }

    }

    @Override
    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
      switch (hash) {
      case -1422950858:
        /* action */ return this.action == null ? new Base[0] : this.action.toArray(new Base[this.action.size()]); // TeardownActionComponent
      default:
        return super.getProperty(hash, name, checkValid);
      }

    }

    @Override
    public Base setProperty(int hash, String name, Base value) throws FHIRException {
      switch (hash) {
      case -1422950858: // action
        this.getAction().add((TeardownActionComponent) value); // TeardownActionComponent
        return value;
      default:
        return super.setProperty(hash, name, value);
      }

    }

    @Override
    public Base setProperty(String name, Base value) throws FHIRException {
      if (name.equals("action")) {
        this.getAction().add((TeardownActionComponent) value);
      } else
        return super.setProperty(name, value);
      return value;
    }

  @Override
  public void removeChild(String name, Base value) throws FHIRException {
      if (name.equals("action")) {
        this.getAction().remove((TeardownActionComponent) value);
      } else
        super.removeChild(name, value);
      
    }

    @Override
    public Base makeProperty(int hash, String name) throws FHIRException {
      switch (hash) {
      case -1422950858:
        return addAction();
      default:
        return super.makeProperty(hash, name);
      }

    }

    @Override
    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
      switch (hash) {
      case -1422950858:
        /* action */ return new String[] {};
      default:
        return super.getTypesForProperty(hash, name);
      }

    }

    @Override
    public Base addChild(String name) throws FHIRException {
      if (name.equals("action")) {
        return addAction();
      } else
        return super.addChild(name);
    }

    public TestReportTeardownComponent copy() {
      TestReportTeardownComponent dst = new TestReportTeardownComponent();
      copyValues(dst);
      return dst;
    }

    public void copyValues(TestReportTeardownComponent dst) {
      super.copyValues(dst);
      if (action != null) {
        dst.action = new ArrayList();
        for (TeardownActionComponent i : action)
          dst.action.add(i.copy());
      }
      ;
    }

    @Override
    public boolean equalsDeep(Base other_) {
      if (!super.equalsDeep(other_))
        return false;
      if (!(other_ instanceof TestReportTeardownComponent))
        return false;
      TestReportTeardownComponent o = (TestReportTeardownComponent) other_;
      return compareDeep(action, o.action, true);
    }

    @Override
    public boolean equalsShallow(Base other_) {
      if (!super.equalsShallow(other_))
        return false;
      if (!(other_ instanceof TestReportTeardownComponent))
        return false;
      TestReportTeardownComponent o = (TestReportTeardownComponent) other_;
      return true;
    }

    public boolean isEmpty() {
      return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(action);
    }

    public String fhirType() {
      return "TestReport.teardown";

    }

  }

  @Block()
  public static class TeardownActionComponent extends BackboneElement implements IBaseBackboneElement {
    /**
     * An operation would involve a REST request to a server.
     */
    @Child(name = "operation", type = {
        SetupActionOperationComponent.class }, order = 1, min = 1, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "The teardown operation performed", formalDefinition = "An operation would involve a REST request to a server.")
    protected SetupActionOperationComponent operation;

    private static final long serialVersionUID = -1099598054L;

    /**
     * Constructor
     */
    public TeardownActionComponent() {
      super();
    }

    /**
     * Constructor
     */
    public TeardownActionComponent(SetupActionOperationComponent operation) {
      super();
      this.operation = operation;
    }

    /**
     * @return {@link #operation} (An operation would involve a REST request to a
     *         server.)
     */
    public SetupActionOperationComponent getOperation() {
      if (this.operation == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create TeardownActionComponent.operation");
        else if (Configuration.doAutoCreate())
          this.operation = new SetupActionOperationComponent(); // cc
      return this.operation;
    }

    public boolean hasOperation() {
      return this.operation != null && !this.operation.isEmpty();
    }

    /**
     * @param value {@link #operation} (An operation would involve a REST request to
     *              a server.)
     */
    public TeardownActionComponent setOperation(SetupActionOperationComponent value) {
      this.operation = value;
      return this;
    }

    protected void listChildren(List children) {
      super.listChildren(children);
      children.add(new Property("operation", "@TestReport.setup.action.operation",
          "An operation would involve a REST request to a server.", 0, 1, operation));
    }

    @Override
    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
      switch (_hash) {
      case 1662702951:
        /* operation */ return new Property("operation", "@TestReport.setup.action.operation",
            "An operation would involve a REST request to a server.", 0, 1, operation);
      default:
        return super.getNamedProperty(_hash, _name, _checkValid);
      }

    }

    @Override
    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
      switch (hash) {
      case 1662702951:
        /* operation */ return this.operation == null ? new Base[0] : new Base[] { this.operation }; // SetupActionOperationComponent
      default:
        return super.getProperty(hash, name, checkValid);
      }

    }

    @Override
    public Base setProperty(int hash, String name, Base value) throws FHIRException {
      switch (hash) {
      case 1662702951: // operation
        this.operation = (SetupActionOperationComponent) value; // SetupActionOperationComponent
        return value;
      default:
        return super.setProperty(hash, name, value);
      }

    }

    @Override
    public Base setProperty(String name, Base value) throws FHIRException {
      if (name.equals("operation")) {
        this.operation = (SetupActionOperationComponent) value; // SetupActionOperationComponent
      } else
        return super.setProperty(name, value);
      return value;
    }

  @Override
  public void removeChild(String name, Base value) throws FHIRException {
      if (name.equals("operation")) {
        this.operation = (SetupActionOperationComponent) value; // SetupActionOperationComponent
      } else
        super.removeChild(name, value);
      
    }

    @Override
    public Base makeProperty(int hash, String name) throws FHIRException {
      switch (hash) {
      case 1662702951:
        return getOperation();
      default:
        return super.makeProperty(hash, name);
      }

    }

    @Override
    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
      switch (hash) {
      case 1662702951:
        /* operation */ return new String[] { "@TestReport.setup.action.operation" };
      default:
        return super.getTypesForProperty(hash, name);
      }

    }

    @Override
    public Base addChild(String name) throws FHIRException {
      if (name.equals("operation")) {
        this.operation = new SetupActionOperationComponent();
        return this.operation;
      } else
        return super.addChild(name);
    }

    public TeardownActionComponent copy() {
      TeardownActionComponent dst = new TeardownActionComponent();
      copyValues(dst);
      return dst;
    }

    public void copyValues(TeardownActionComponent dst) {
      super.copyValues(dst);
      dst.operation = operation == null ? null : operation.copy();
    }

    @Override
    public boolean equalsDeep(Base other_) {
      if (!super.equalsDeep(other_))
        return false;
      if (!(other_ instanceof TeardownActionComponent))
        return false;
      TeardownActionComponent o = (TeardownActionComponent) other_;
      return compareDeep(operation, o.operation, true);
    }

    @Override
    public boolean equalsShallow(Base other_) {
      if (!super.equalsShallow(other_))
        return false;
      if (!(other_ instanceof TeardownActionComponent))
        return false;
      TeardownActionComponent o = (TeardownActionComponent) other_;
      return true;
    }

    public boolean isEmpty() {
      return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(operation);
    }

    public String fhirType() {
      return "TestReport.teardown.action";

    }

  }

  /**
   * Identifier for the TestScript assigned for external purposes outside the
   * context of FHIR.
   */
  @Child(name = "identifier", type = {
      Identifier.class }, order = 0, min = 0, max = 1, modifier = false, summary = true)
  @Description(shortDefinition = "External identifier", formalDefinition = "Identifier for the TestScript assigned for external purposes outside the context of FHIR.")
  protected Identifier identifier;

  /**
   * A free text natural language name identifying the executed TestScript.
   */
  @Child(name = "name", type = { StringType.class }, order = 1, min = 0, max = 1, modifier = false, summary = true)
  @Description(shortDefinition = "Informal name of the executed TestScript", formalDefinition = "A free text natural language name identifying the executed TestScript.")
  protected StringType name;

  /**
   * The current state of this test report.
   */
  @Child(name = "status", type = { CodeType.class }, order = 2, min = 1, max = 1, modifier = true, summary = true)
  @Description(shortDefinition = "completed | in-progress | waiting | stopped | entered-in-error", formalDefinition = "The current state of this test report.")
  @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/report-status-codes")
  protected Enumeration status;

  /**
   * Ideally this is an absolute URL that is used to identify the version-specific
   * TestScript that was executed, matching the `TestScript.url`.
   */
  @Child(name = "testScript", type = {
      TestScript.class }, order = 3, min = 1, max = 1, modifier = false, summary = true)
  @Description(shortDefinition = "Reference to the  version-specific TestScript that was executed to produce this TestReport", formalDefinition = "Ideally this is an absolute URL that is used to identify the version-specific TestScript that was executed, matching the `TestScript.url`.")
  protected Reference testScript;

  /**
   * The actual object that is the target of the reference (Ideally this is an
   * absolute URL that is used to identify the version-specific TestScript that
   * was executed, matching the `TestScript.url`.)
   */
  protected TestScript testScriptTarget;

  /**
   * The overall result from the execution of the TestScript.
   */
  @Child(name = "result", type = { CodeType.class }, order = 4, min = 1, max = 1, modifier = false, summary = true)
  @Description(shortDefinition = "pass | fail | pending", formalDefinition = "The overall result from the execution of the TestScript.")
  @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/report-result-codes")
  protected Enumeration result;

  /**
   * The final score (percentage of tests passed) resulting from the execution of
   * the TestScript.
   */
  @Child(name = "score", type = { DecimalType.class }, order = 5, min = 0, max = 1, modifier = false, summary = true)
  @Description(shortDefinition = "The final score (percentage of tests passed) resulting from the execution of the TestScript", formalDefinition = "The final score (percentage of tests passed) resulting from the execution of the TestScript.")
  protected DecimalType score;

  /**
   * Name of the tester producing this report (Organization or individual).
   */
  @Child(name = "tester", type = { StringType.class }, order = 6, min = 0, max = 1, modifier = false, summary = true)
  @Description(shortDefinition = "Name of the tester producing this report (Organization or individual)", formalDefinition = "Name of the tester producing this report (Organization or individual).")
  protected StringType tester;

  /**
   * When the TestScript was executed and this TestReport was generated.
   */
  @Child(name = "issued", type = { DateTimeType.class }, order = 7, min = 0, max = 1, modifier = false, summary = true)
  @Description(shortDefinition = "When the TestScript was executed and this TestReport was generated", formalDefinition = "When the TestScript was executed and this TestReport was generated.")
  protected DateTimeType issued;

  /**
   * A participant in the test execution, either the execution engine, a client,
   * or a server.
   */
  @Child(name = "participant", type = {}, order = 8, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
  @Description(shortDefinition = "A participant in the test execution, either the execution engine, a client, or a server", formalDefinition = "A participant in the test execution, either the execution engine, a client, or a server.")
  protected List participant;

  /**
   * The results of the series of required setup operations before the tests were
   * executed.
   */
  @Child(name = "setup", type = {}, order = 9, min = 0, max = 1, modifier = false, summary = false)
  @Description(shortDefinition = "The results of the series of required setup operations before the tests were executed", formalDefinition = "The results of the series of required setup operations before the tests were executed.")
  protected TestReportSetupComponent setup;

  /**
   * A test executed from the test script.
   */
  @Child(name = "test", type = {}, order = 10, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
  @Description(shortDefinition = "A test executed from the test script", formalDefinition = "A test executed from the test script.")
  protected List test;

  /**
   * The results of the series of operations required to clean up after all the
   * tests were executed (successfully or otherwise).
   */
  @Child(name = "teardown", type = {}, order = 11, min = 0, max = 1, modifier = false, summary = false)
  @Description(shortDefinition = "The results of running the series of required clean up steps", formalDefinition = "The results of the series of operations required to clean up after all the tests were executed (successfully or otherwise).")
  protected TestReportTeardownComponent teardown;

  private static final long serialVersionUID = 79474516L;

  /**
   * Constructor
   */
  public TestReport() {
    super();
  }

  /**
   * Constructor
   */
  public TestReport(Enumeration status, Reference testScript, Enumeration result) {
    super();
    this.status = status;
    this.testScript = testScript;
    this.result = result;
  }

  /**
   * @return {@link #identifier} (Identifier for the TestScript assigned for
   *         external purposes outside the context of FHIR.)
   */
  public Identifier getIdentifier() {
    if (this.identifier == null)
      if (Configuration.errorOnAutoCreate())
        throw new Error("Attempt to auto-create TestReport.identifier");
      else if (Configuration.doAutoCreate())
        this.identifier = new Identifier(); // cc
    return this.identifier;
  }

  public boolean hasIdentifier() {
    return this.identifier != null && !this.identifier.isEmpty();
  }

  /**
   * @param value {@link #identifier} (Identifier for the TestScript assigned for
   *              external purposes outside the context of FHIR.)
   */
  public TestReport setIdentifier(Identifier value) {
    this.identifier = value;
    return this;
  }

  /**
   * @return {@link #name} (A free text natural language name identifying the
   *         executed TestScript.). This is the underlying object with id, value
   *         and extensions. The accessor "getName" gives direct access to the
   *         value
   */
  public StringType getNameElement() {
    if (this.name == null)
      if (Configuration.errorOnAutoCreate())
        throw new Error("Attempt to auto-create TestReport.name");
      else if (Configuration.doAutoCreate())
        this.name = new StringType(); // bb
    return this.name;
  }

  public boolean hasNameElement() {
    return this.name != null && !this.name.isEmpty();
  }

  public boolean hasName() {
    return this.name != null && !this.name.isEmpty();
  }

  /**
   * @param value {@link #name} (A free text natural language name identifying the
   *              executed TestScript.). This is the underlying object with id,
   *              value and extensions. The accessor "getName" gives direct access
   *              to the value
   */
  public TestReport setNameElement(StringType value) {
    this.name = value;
    return this;
  }

  /**
   * @return A free text natural language name identifying the executed
   *         TestScript.
   */
  public String getName() {
    return this.name == null ? null : this.name.getValue();
  }

  /**
   * @param value A free text natural language name identifying the executed
   *              TestScript.
   */
  public TestReport setName(String value) {
    if (Utilities.noString(value))
      this.name = null;
    else {
      if (this.name == null)
        this.name = new StringType();
      this.name.setValue(value);
    }
    return this;
  }

  /**
   * @return {@link #status} (The current state of this test report.). This is the
   *         underlying object with id, value and extensions. The accessor
   *         "getStatus" gives direct access to the value
   */
  public Enumeration getStatusElement() {
    if (this.status == null)
      if (Configuration.errorOnAutoCreate())
        throw new Error("Attempt to auto-create TestReport.status");
      else if (Configuration.doAutoCreate())
        this.status = new Enumeration(new TestReportStatusEnumFactory()); // bb
    return this.status;
  }

  public boolean hasStatusElement() {
    return this.status != null && !this.status.isEmpty();
  }

  public boolean hasStatus() {
    return this.status != null && !this.status.isEmpty();
  }

  /**
   * @param value {@link #status} (The current state of this test report.). This
   *              is the underlying object with id, value and extensions. The
   *              accessor "getStatus" gives direct access to the value
   */
  public TestReport setStatusElement(Enumeration value) {
    this.status = value;
    return this;
  }

  /**
   * @return The current state of this test report.
   */
  public TestReportStatus getStatus() {
    return this.status == null ? null : this.status.getValue();
  }

  /**
   * @param value The current state of this test report.
   */
  public TestReport setStatus(TestReportStatus value) {
    if (this.status == null)
      this.status = new Enumeration(new TestReportStatusEnumFactory());
    this.status.setValue(value);
    return this;
  }

  /**
   * @return {@link #testScript} (Ideally this is an absolute URL that is used to
   *         identify the version-specific TestScript that was executed, matching
   *         the `TestScript.url`.)
   */
  public Reference getTestScript() {
    if (this.testScript == null)
      if (Configuration.errorOnAutoCreate())
        throw new Error("Attempt to auto-create TestReport.testScript");
      else if (Configuration.doAutoCreate())
        this.testScript = new Reference(); // cc
    return this.testScript;
  }

  public boolean hasTestScript() {
    return this.testScript != null && !this.testScript.isEmpty();
  }

  /**
   * @param value {@link #testScript} (Ideally this is an absolute URL that is
   *              used to identify the version-specific TestScript that was
   *              executed, matching the `TestScript.url`.)
   */
  public TestReport setTestScript(Reference value) {
    this.testScript = value;
    return this;
  }

  /**
   * @return {@link #testScript} The actual object that is the target of the
   *         reference. The reference library doesn't populate this, but you can
   *         use it to hold the resource if you resolve it. (Ideally this is an
   *         absolute URL that is used to identify the version-specific TestScript
   *         that was executed, matching the `TestScript.url`.)
   */
  public TestScript getTestScriptTarget() {
    if (this.testScriptTarget == null)
      if (Configuration.errorOnAutoCreate())
        throw new Error("Attempt to auto-create TestReport.testScript");
      else if (Configuration.doAutoCreate())
        this.testScriptTarget = new TestScript(); // aa
    return this.testScriptTarget;
  }

  /**
   * @param value {@link #testScript} The actual object that is the target of the
   *              reference. The reference library doesn't use these, but you can
   *              use it to hold the resource if you resolve it. (Ideally this is
   *              an absolute URL that is used to identify the version-specific
   *              TestScript that was executed, matching the `TestScript.url`.)
   */
  public TestReport setTestScriptTarget(TestScript value) {
    this.testScriptTarget = value;
    return this;
  }

  /**
   * @return {@link #result} (The overall result from the execution of the
   *         TestScript.). This is the underlying object with id, value and
   *         extensions. The accessor "getResult" gives direct access to the value
   */
  public Enumeration getResultElement() {
    if (this.result == null)
      if (Configuration.errorOnAutoCreate())
        throw new Error("Attempt to auto-create TestReport.result");
      else if (Configuration.doAutoCreate())
        this.result = new Enumeration(new TestReportResultEnumFactory()); // bb
    return this.result;
  }

  public boolean hasResultElement() {
    return this.result != null && !this.result.isEmpty();
  }

  public boolean hasResult() {
    return this.result != null && !this.result.isEmpty();
  }

  /**
   * @param value {@link #result} (The overall result from the execution of the
   *              TestScript.). This is the underlying object with id, value and
   *              extensions. The accessor "getResult" gives direct access to the
   *              value
   */
  public TestReport setResultElement(Enumeration value) {
    this.result = value;
    return this;
  }

  /**
   * @return The overall result from the execution of the TestScript.
   */
  public TestReportResult getResult() {
    return this.result == null ? null : this.result.getValue();
  }

  /**
   * @param value The overall result from the execution of the TestScript.
   */
  public TestReport setResult(TestReportResult value) {
    if (this.result == null)
      this.result = new Enumeration(new TestReportResultEnumFactory());
    this.result.setValue(value);
    return this;
  }

  /**
   * @return {@link #score} (The final score (percentage of tests passed)
   *         resulting from the execution of the TestScript.). This is the
   *         underlying object with id, value and extensions. The accessor
   *         "getScore" gives direct access to the value
   */
  public DecimalType getScoreElement() {
    if (this.score == null)
      if (Configuration.errorOnAutoCreate())
        throw new Error("Attempt to auto-create TestReport.score");
      else if (Configuration.doAutoCreate())
        this.score = new DecimalType(); // bb
    return this.score;
  }

  public boolean hasScoreElement() {
    return this.score != null && !this.score.isEmpty();
  }

  public boolean hasScore() {
    return this.score != null && !this.score.isEmpty();
  }

  /**
   * @param value {@link #score} (The final score (percentage of tests passed)
   *              resulting from the execution of the TestScript.). This is the
   *              underlying object with id, value and extensions. The accessor
   *              "getScore" gives direct access to the value
   */
  public TestReport setScoreElement(DecimalType value) {
    this.score = value;
    return this;
  }

  /**
   * @return The final score (percentage of tests passed) resulting from the
   *         execution of the TestScript.
   */
  public BigDecimal getScore() {
    return this.score == null ? null : this.score.getValue();
  }

  /**
   * @param value The final score (percentage of tests passed) resulting from the
   *              execution of the TestScript.
   */
  public TestReport setScore(BigDecimal value) {
    if (value == null)
      this.score = null;
    else {
      if (this.score == null)
        this.score = new DecimalType();
      this.score.setValue(value);
    }
    return this;
  }

  /**
   * @param value The final score (percentage of tests passed) resulting from the
   *              execution of the TestScript.
   */
  public TestReport setScore(long value) {
    this.score = new DecimalType();
    this.score.setValue(value);
    return this;
  }

  /**
   * @param value The final score (percentage of tests passed) resulting from the
   *              execution of the TestScript.
   */
  public TestReport setScore(double value) {
    this.score = new DecimalType();
    this.score.setValue(value);
    return this;
  }

  /**
   * @return {@link #tester} (Name of the tester producing this report
   *         (Organization or individual).). This is the underlying object with
   *         id, value and extensions. The accessor "getTester" gives direct
   *         access to the value
   */
  public StringType getTesterElement() {
    if (this.tester == null)
      if (Configuration.errorOnAutoCreate())
        throw new Error("Attempt to auto-create TestReport.tester");
      else if (Configuration.doAutoCreate())
        this.tester = new StringType(); // bb
    return this.tester;
  }

  public boolean hasTesterElement() {
    return this.tester != null && !this.tester.isEmpty();
  }

  public boolean hasTester() {
    return this.tester != null && !this.tester.isEmpty();
  }

  /**
   * @param value {@link #tester} (Name of the tester producing this report
   *              (Organization or individual).). This is the underlying object
   *              with id, value and extensions. The accessor "getTester" gives
   *              direct access to the value
   */
  public TestReport setTesterElement(StringType value) {
    this.tester = value;
    return this;
  }

  /**
   * @return Name of the tester producing this report (Organization or
   *         individual).
   */
  public String getTester() {
    return this.tester == null ? null : this.tester.getValue();
  }

  /**
   * @param value Name of the tester producing this report (Organization or
   *              individual).
   */
  public TestReport setTester(String value) {
    if (Utilities.noString(value))
      this.tester = null;
    else {
      if (this.tester == null)
        this.tester = new StringType();
      this.tester.setValue(value);
    }
    return this;
  }

  /**
   * @return {@link #issued} (When the TestScript was executed and this TestReport
   *         was generated.). This is the underlying object with id, value and
   *         extensions. The accessor "getIssued" gives direct access to the value
   */
  public DateTimeType getIssuedElement() {
    if (this.issued == null)
      if (Configuration.errorOnAutoCreate())
        throw new Error("Attempt to auto-create TestReport.issued");
      else if (Configuration.doAutoCreate())
        this.issued = new DateTimeType(); // bb
    return this.issued;
  }

  public boolean hasIssuedElement() {
    return this.issued != null && !this.issued.isEmpty();
  }

  public boolean hasIssued() {
    return this.issued != null && !this.issued.isEmpty();
  }

  /**
   * @param value {@link #issued} (When the TestScript was executed and this
   *              TestReport was generated.). This is the underlying object with
   *              id, value and extensions. The accessor "getIssued" gives direct
   *              access to the value
   */
  public TestReport setIssuedElement(DateTimeType value) {
    this.issued = value;
    return this;
  }

  /**
   * @return When the TestScript was executed and this TestReport was generated.
   */
  public Date getIssued() {
    return this.issued == null ? null : this.issued.getValue();
  }

  /**
   * @param value When the TestScript was executed and this TestReport was
   *              generated.
   */
  public TestReport setIssued(Date value) {
    if (value == null)
      this.issued = null;
    else {
      if (this.issued == null)
        this.issued = new DateTimeType();
      this.issued.setValue(value);
    }
    return this;
  }

  /**
   * @return {@link #participant} (A participant in the test execution, either the
   *         execution engine, a client, or a server.)
   */
  public List getParticipant() {
    if (this.participant == null)
      this.participant = new ArrayList();
    return this.participant;
  }

  /**
   * @return Returns a reference to this for easy method chaining
   */
  public TestReport setParticipant(List theParticipant) {
    this.participant = theParticipant;
    return this;
  }

  public boolean hasParticipant() {
    if (this.participant == null)
      return false;
    for (TestReportParticipantComponent item : this.participant)
      if (!item.isEmpty())
        return true;
    return false;
  }

  public TestReportParticipantComponent addParticipant() { // 3
    TestReportParticipantComponent t = new TestReportParticipantComponent();
    if (this.participant == null)
      this.participant = new ArrayList();
    this.participant.add(t);
    return t;
  }

  public TestReport addParticipant(TestReportParticipantComponent t) { // 3
    if (t == null)
      return this;
    if (this.participant == null)
      this.participant = new ArrayList();
    this.participant.add(t);
    return this;
  }

  /**
   * @return The first repetition of repeating field {@link #participant},
   *         creating it if it does not already exist
   */
  public TestReportParticipantComponent getParticipantFirstRep() {
    if (getParticipant().isEmpty()) {
      addParticipant();
    }
    return getParticipant().get(0);
  }

  /**
   * @return {@link #setup} (The results of the series of required setup
   *         operations before the tests were executed.)
   */
  public TestReportSetupComponent getSetup() {
    if (this.setup == null)
      if (Configuration.errorOnAutoCreate())
        throw new Error("Attempt to auto-create TestReport.setup");
      else if (Configuration.doAutoCreate())
        this.setup = new TestReportSetupComponent(); // cc
    return this.setup;
  }

  public boolean hasSetup() {
    return this.setup != null && !this.setup.isEmpty();
  }

  /**
   * @param value {@link #setup} (The results of the series of required setup
   *              operations before the tests were executed.)
   */
  public TestReport setSetup(TestReportSetupComponent value) {
    this.setup = value;
    return this;
  }

  /**
   * @return {@link #test} (A test executed from the test script.)
   */
  public List getTest() {
    if (this.test == null)
      this.test = new ArrayList();
    return this.test;
  }

  /**
   * @return Returns a reference to this for easy method chaining
   */
  public TestReport setTest(List theTest) {
    this.test = theTest;
    return this;
  }

  public boolean hasTest() {
    if (this.test == null)
      return false;
    for (TestReportTestComponent item : this.test)
      if (!item.isEmpty())
        return true;
    return false;
  }

  public TestReportTestComponent addTest() { // 3
    TestReportTestComponent t = new TestReportTestComponent();
    if (this.test == null)
      this.test = new ArrayList();
    this.test.add(t);
    return t;
  }

  public TestReport addTest(TestReportTestComponent t) { // 3
    if (t == null)
      return this;
    if (this.test == null)
      this.test = new ArrayList();
    this.test.add(t);
    return this;
  }

  /**
   * @return The first repetition of repeating field {@link #test}, creating it if
   *         it does not already exist
   */
  public TestReportTestComponent getTestFirstRep() {
    if (getTest().isEmpty()) {
      addTest();
    }
    return getTest().get(0);
  }

  /**
   * @return {@link #teardown} (The results of the series of operations required
   *         to clean up after all the tests were executed (successfully or
   *         otherwise).)
   */
  public TestReportTeardownComponent getTeardown() {
    if (this.teardown == null)
      if (Configuration.errorOnAutoCreate())
        throw new Error("Attempt to auto-create TestReport.teardown");
      else if (Configuration.doAutoCreate())
        this.teardown = new TestReportTeardownComponent(); // cc
    return this.teardown;
  }

  public boolean hasTeardown() {
    return this.teardown != null && !this.teardown.isEmpty();
  }

  /**
   * @param value {@link #teardown} (The results of the series of operations
   *              required to clean up after all the tests were executed
   *              (successfully or otherwise).)
   */
  public TestReport setTeardown(TestReportTeardownComponent value) {
    this.teardown = value;
    return this;
  }

  protected void listChildren(List children) {
    super.listChildren(children);
    children.add(new Property("identifier", "Identifier",
        "Identifier for the TestScript assigned for external purposes outside the context of FHIR.", 0, 1, identifier));
    children.add(new Property("name", "string",
        "A free text natural language name identifying the executed TestScript.", 0, 1, name));
    children.add(new Property("status", "code", "The current state of this test report.", 0, 1, status));
    children.add(new Property("testScript", "Reference(TestScript)",
        "Ideally this is an absolute URL that is used to identify the version-specific TestScript that was executed, matching the `TestScript.url`.",
        0, 1, testScript));
    children
        .add(new Property("result", "code", "The overall result from the execution of the TestScript.", 0, 1, result));
    children.add(new Property("score", "decimal",
        "The final score (percentage of tests passed) resulting from the execution of the TestScript.", 0, 1, score));
    children.add(new Property("tester", "string",
        "Name of the tester producing this report (Organization or individual).", 0, 1, tester));
    children.add(new Property("issued", "dateTime",
        "When the TestScript was executed and this TestReport was generated.", 0, 1, issued));
    children.add(new Property("participant", "",
        "A participant in the test execution, either the execution engine, a client, or a server.", 0,
        java.lang.Integer.MAX_VALUE, participant));
    children.add(new Property("setup", "",
        "The results of the series of required setup operations before the tests were executed.", 0, 1, setup));
    children
        .add(new Property("test", "", "A test executed from the test script.", 0, java.lang.Integer.MAX_VALUE, test));
    children.add(new Property("teardown", "",
        "The results of the series of operations required to clean up after all the tests were executed (successfully or otherwise).",
        0, 1, teardown));
  }

  @Override
  public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
    switch (_hash) {
    case -1618432855:
      /* identifier */ return new Property("identifier", "Identifier",
          "Identifier for the TestScript assigned for external purposes outside the context of FHIR.", 0, 1,
          identifier);
    case 3373707:
      /* name */ return new Property("name", "string",
          "A free text natural language name identifying the executed TestScript.", 0, 1, name);
    case -892481550:
      /* status */ return new Property("status", "code", "The current state of this test report.", 0, 1, status);
    case 1712049149:
      /* testScript */ return new Property("testScript", "Reference(TestScript)",
          "Ideally this is an absolute URL that is used to identify the version-specific TestScript that was executed, matching the `TestScript.url`.",
          0, 1, testScript);
    case -934426595:
      /* result */ return new Property("result", "code", "The overall result from the execution of the TestScript.", 0,
          1, result);
    case 109264530:
      /* score */ return new Property("score", "decimal",
          "The final score (percentage of tests passed) resulting from the execution of the TestScript.", 0, 1, score);
    case -877169473:
      /* tester */ return new Property("tester", "string",
          "Name of the tester producing this report (Organization or individual).", 0, 1, tester);
    case -1179159893:
      /* issued */ return new Property("issued", "dateTime",
          "When the TestScript was executed and this TestReport was generated.", 0, 1, issued);
    case 767422259:
      /* participant */ return new Property("participant", "",
          "A participant in the test execution, either the execution engine, a client, or a server.", 0,
          java.lang.Integer.MAX_VALUE, participant);
    case 109329021:
      /* setup */ return new Property("setup", "",
          "The results of the series of required setup operations before the tests were executed.", 0, 1, setup);
    case 3556498:
      /* test */ return new Property("test", "", "A test executed from the test script.", 0,
          java.lang.Integer.MAX_VALUE, test);
    case -1663474172:
      /* teardown */ return new Property("teardown", "",
          "The results of the series of operations required to clean up after all the tests were executed (successfully or otherwise).",
          0, 1, teardown);
    default:
      return super.getNamedProperty(_hash, _name, _checkValid);
    }

  }

  @Override
  public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
    switch (hash) {
    case -1618432855:
      /* identifier */ return this.identifier == null ? new Base[0] : new Base[] { this.identifier }; // Identifier
    case 3373707:
      /* name */ return this.name == null ? new Base[0] : new Base[] { this.name }; // StringType
    case -892481550:
      /* status */ return this.status == null ? new Base[0] : new Base[] { this.status }; // Enumeration
    case 1712049149:
      /* testScript */ return this.testScript == null ? new Base[0] : new Base[] { this.testScript }; // Reference
    case -934426595:
      /* result */ return this.result == null ? new Base[0] : new Base[] { this.result }; // Enumeration
    case 109264530:
      /* score */ return this.score == null ? new Base[0] : new Base[] { this.score }; // DecimalType
    case -877169473:
      /* tester */ return this.tester == null ? new Base[0] : new Base[] { this.tester }; // StringType
    case -1179159893:
      /* issued */ return this.issued == null ? new Base[0] : new Base[] { this.issued }; // DateTimeType
    case 767422259:
      /* participant */ return this.participant == null ? new Base[0]
          : this.participant.toArray(new Base[this.participant.size()]); // TestReportParticipantComponent
    case 109329021:
      /* setup */ return this.setup == null ? new Base[0] : new Base[] { this.setup }; // TestReportSetupComponent
    case 3556498:
      /* test */ return this.test == null ? new Base[0] : this.test.toArray(new Base[this.test.size()]); // TestReportTestComponent
    case -1663474172:
      /* teardown */ return this.teardown == null ? new Base[0] : new Base[] { this.teardown }; // TestReportTeardownComponent
    default:
      return super.getProperty(hash, name, checkValid);
    }

  }

  @Override
  public Base setProperty(int hash, String name, Base value) throws FHIRException {
    switch (hash) {
    case -1618432855: // identifier
      this.identifier = castToIdentifier(value); // Identifier
      return value;
    case 3373707: // name
      this.name = castToString(value); // StringType
      return value;
    case -892481550: // status
      value = new TestReportStatusEnumFactory().fromType(castToCode(value));
      this.status = (Enumeration) value; // Enumeration
      return value;
    case 1712049149: // testScript
      this.testScript = castToReference(value); // Reference
      return value;
    case -934426595: // result
      value = new TestReportResultEnumFactory().fromType(castToCode(value));
      this.result = (Enumeration) value; // Enumeration
      return value;
    case 109264530: // score
      this.score = castToDecimal(value); // DecimalType
      return value;
    case -877169473: // tester
      this.tester = castToString(value); // StringType
      return value;
    case -1179159893: // issued
      this.issued = castToDateTime(value); // DateTimeType
      return value;
    case 767422259: // participant
      this.getParticipant().add((TestReportParticipantComponent) value); // TestReportParticipantComponent
      return value;
    case 109329021: // setup
      this.setup = (TestReportSetupComponent) value; // TestReportSetupComponent
      return value;
    case 3556498: // test
      this.getTest().add((TestReportTestComponent) value); // TestReportTestComponent
      return value;
    case -1663474172: // teardown
      this.teardown = (TestReportTeardownComponent) value; // TestReportTeardownComponent
      return value;
    default:
      return super.setProperty(hash, name, value);
    }

  }

  @Override
  public Base setProperty(String name, Base value) throws FHIRException {
    if (name.equals("identifier")) {
      this.identifier = castToIdentifier(value); // Identifier
    } else if (name.equals("name")) {
      this.name = castToString(value); // StringType
    } else if (name.equals("status")) {
      value = new TestReportStatusEnumFactory().fromType(castToCode(value));
      this.status = (Enumeration) value; // Enumeration
    } else if (name.equals("testScript")) {
      this.testScript = castToReference(value); // Reference
    } else if (name.equals("result")) {
      value = new TestReportResultEnumFactory().fromType(castToCode(value));
      this.result = (Enumeration) value; // Enumeration
    } else if (name.equals("score")) {
      this.score = castToDecimal(value); // DecimalType
    } else if (name.equals("tester")) {
      this.tester = castToString(value); // StringType
    } else if (name.equals("issued")) {
      this.issued = castToDateTime(value); // DateTimeType
    } else if (name.equals("participant")) {
      this.getParticipant().add((TestReportParticipantComponent) value);
    } else if (name.equals("setup")) {
      this.setup = (TestReportSetupComponent) value; // TestReportSetupComponent
    } else if (name.equals("test")) {
      this.getTest().add((TestReportTestComponent) value);
    } else if (name.equals("teardown")) {
      this.teardown = (TestReportTeardownComponent) value; // TestReportTeardownComponent
    } else
      return super.setProperty(name, value);
    return value;
  }

  @Override
  public void removeChild(String name, Base value) throws FHIRException {
    if (name.equals("identifier")) {
      this.identifier = null;
    } else if (name.equals("name")) {
      this.name = null;
    } else if (name.equals("status")) {
      this.status = null;
    } else if (name.equals("testScript")) {
      this.testScript = null;
    } else if (name.equals("result")) {
      this.result = null;
    } else if (name.equals("score")) {
      this.score = null;
    } else if (name.equals("tester")) {
      this.tester = null;
    } else if (name.equals("issued")) {
      this.issued = null;
    } else if (name.equals("participant")) {
      this.getParticipant().remove((TestReportParticipantComponent) value);
    } else if (name.equals("setup")) {
      this.setup = (TestReportSetupComponent) value; // TestReportSetupComponent
    } else if (name.equals("test")) {
      this.getTest().remove((TestReportTestComponent) value);
    } else if (name.equals("teardown")) {
      this.teardown = (TestReportTeardownComponent) value; // TestReportTeardownComponent
    } else
      super.removeChild(name, value);
    
  }

  @Override
  public Base makeProperty(int hash, String name) throws FHIRException {
    switch (hash) {
    case -1618432855:
      return getIdentifier();
    case 3373707:
      return getNameElement();
    case -892481550:
      return getStatusElement();
    case 1712049149:
      return getTestScript();
    case -934426595:
      return getResultElement();
    case 109264530:
      return getScoreElement();
    case -877169473:
      return getTesterElement();
    case -1179159893:
      return getIssuedElement();
    case 767422259:
      return addParticipant();
    case 109329021:
      return getSetup();
    case 3556498:
      return addTest();
    case -1663474172:
      return getTeardown();
    default:
      return super.makeProperty(hash, name);
    }

  }

  @Override
  public String[] getTypesForProperty(int hash, String name) throws FHIRException {
    switch (hash) {
    case -1618432855:
      /* identifier */ return new String[] { "Identifier" };
    case 3373707:
      /* name */ return new String[] { "string" };
    case -892481550:
      /* status */ return new String[] { "code" };
    case 1712049149:
      /* testScript */ return new String[] { "Reference" };
    case -934426595:
      /* result */ return new String[] { "code" };
    case 109264530:
      /* score */ return new String[] { "decimal" };
    case -877169473:
      /* tester */ return new String[] { "string" };
    case -1179159893:
      /* issued */ return new String[] { "dateTime" };
    case 767422259:
      /* participant */ return new String[] {};
    case 109329021:
      /* setup */ return new String[] {};
    case 3556498:
      /* test */ return new String[] {};
    case -1663474172:
      /* teardown */ return new String[] {};
    default:
      return super.getTypesForProperty(hash, name);
    }

  }

  @Override
  public Base addChild(String name) throws FHIRException {
    if (name.equals("identifier")) {
      this.identifier = new Identifier();
      return this.identifier;
    } else if (name.equals("name")) {
      throw new FHIRException("Cannot call addChild on a singleton property TestReport.name");
    } else if (name.equals("status")) {
      throw new FHIRException("Cannot call addChild on a singleton property TestReport.status");
    } else if (name.equals("testScript")) {
      this.testScript = new Reference();
      return this.testScript;
    } else if (name.equals("result")) {
      throw new FHIRException("Cannot call addChild on a singleton property TestReport.result");
    } else if (name.equals("score")) {
      throw new FHIRException("Cannot call addChild on a singleton property TestReport.score");
    } else if (name.equals("tester")) {
      throw new FHIRException("Cannot call addChild on a singleton property TestReport.tester");
    } else if (name.equals("issued")) {
      throw new FHIRException("Cannot call addChild on a singleton property TestReport.issued");
    } else if (name.equals("participant")) {
      return addParticipant();
    } else if (name.equals("setup")) {
      this.setup = new TestReportSetupComponent();
      return this.setup;
    } else if (name.equals("test")) {
      return addTest();
    } else if (name.equals("teardown")) {
      this.teardown = new TestReportTeardownComponent();
      return this.teardown;
    } else
      return super.addChild(name);
  }

  public String fhirType() {
    return "TestReport";

  }

  public TestReport copy() {
    TestReport dst = new TestReport();
    copyValues(dst);
    return dst;
  }

  public void copyValues(TestReport dst) {
    super.copyValues(dst);
    dst.identifier = identifier == null ? null : identifier.copy();
    dst.name = name == null ? null : name.copy();
    dst.status = status == null ? null : status.copy();
    dst.testScript = testScript == null ? null : testScript.copy();
    dst.result = result == null ? null : result.copy();
    dst.score = score == null ? null : score.copy();
    dst.tester = tester == null ? null : tester.copy();
    dst.issued = issued == null ? null : issued.copy();
    if (participant != null) {
      dst.participant = new ArrayList();
      for (TestReportParticipantComponent i : participant)
        dst.participant.add(i.copy());
    }
    ;
    dst.setup = setup == null ? null : setup.copy();
    if (test != null) {
      dst.test = new ArrayList();
      for (TestReportTestComponent i : test)
        dst.test.add(i.copy());
    }
    ;
    dst.teardown = teardown == null ? null : teardown.copy();
  }

  protected TestReport typedCopy() {
    return copy();
  }

  @Override
  public boolean equalsDeep(Base other_) {
    if (!super.equalsDeep(other_))
      return false;
    if (!(other_ instanceof TestReport))
      return false;
    TestReport o = (TestReport) other_;
    return compareDeep(identifier, o.identifier, true) && compareDeep(name, o.name, true)
        && compareDeep(status, o.status, true) && compareDeep(testScript, o.testScript, true)
        && compareDeep(result, o.result, true) && compareDeep(score, o.score, true)
        && compareDeep(tester, o.tester, true) && compareDeep(issued, o.issued, true)
        && compareDeep(participant, o.participant, true) && compareDeep(setup, o.setup, true)
        && compareDeep(test, o.test, true) && compareDeep(teardown, o.teardown, true);
  }

  @Override
  public boolean equalsShallow(Base other_) {
    if (!super.equalsShallow(other_))
      return false;
    if (!(other_ instanceof TestReport))
      return false;
    TestReport o = (TestReport) other_;
    return compareValues(name, o.name, true) && compareValues(status, o.status, true)
        && compareValues(result, o.result, true) && compareValues(score, o.score, true)
        && compareValues(tester, o.tester, true) && compareValues(issued, o.issued, true);
  }

  public boolean isEmpty() {
    return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(identifier, name, status, testScript, result, score,
        tester, issued, participant, setup, test, teardown);
  }

  @Override
  public ResourceType getResourceType() {
    return ResourceType.TestReport;
  }

  /**
   * Search parameter: result
   * 

* Description: The result disposition of the test execution
* Type: token
* Path: TestReport.result
*

*/ @SearchParamDefinition(name = "result", path = "TestReport.result", description = "The result disposition of the test execution", type = "token") public static final String SP_RESULT = "result"; /** * Fluent Client search parameter constant for result *

* Description: The result disposition of the test execution
* Type: token
* Path: TestReport.result
*

*/ public static final ca.uhn.fhir.rest.gclient.TokenClientParam RESULT = new ca.uhn.fhir.rest.gclient.TokenClientParam( SP_RESULT); /** * Search parameter: identifier *

* Description: An external identifier for the test report
* Type: token
* Path: TestReport.identifier
*

*/ @SearchParamDefinition(name = "identifier", path = "TestReport.identifier", description = "An external identifier for the test report", type = "token") public static final String SP_IDENTIFIER = "identifier"; /** * Fluent Client search parameter constant for identifier *

* Description: An external identifier for the test report
* Type: token
* Path: TestReport.identifier
*

*/ public static final ca.uhn.fhir.rest.gclient.TokenClientParam IDENTIFIER = new ca.uhn.fhir.rest.gclient.TokenClientParam( SP_IDENTIFIER); /** * Search parameter: tester *

* Description: The name of the testing organization
* Type: string
* Path: TestReport.tester
*

*/ @SearchParamDefinition(name = "tester", path = "TestReport.tester", description = "The name of the testing organization", type = "string") public static final String SP_TESTER = "tester"; /** * Fluent Client search parameter constant for tester *

* Description: The name of the testing organization
* Type: string
* Path: TestReport.tester
*

*/ public static final ca.uhn.fhir.rest.gclient.StringClientParam TESTER = new ca.uhn.fhir.rest.gclient.StringClientParam( SP_TESTER); /** * Search parameter: testscript *

* Description: The test script executed to produce this report
* Type: reference
* Path: TestReport.testScript
*

*/ @SearchParamDefinition(name = "testscript", path = "TestReport.testScript", description = "The test script executed to produce this report", type = "reference", target = { TestScript.class }) public static final String SP_TESTSCRIPT = "testscript"; /** * Fluent Client search parameter constant for testscript *

* Description: The test script executed to produce this report
* Type: reference
* Path: TestReport.testScript
*

*/ public static final ca.uhn.fhir.rest.gclient.ReferenceClientParam TESTSCRIPT = new ca.uhn.fhir.rest.gclient.ReferenceClientParam( SP_TESTSCRIPT); /** * Constant for fluent queries to be used to add include statements. Specifies * the path value of "TestReport:testscript". */ public static final ca.uhn.fhir.model.api.Include INCLUDE_TESTSCRIPT = new ca.uhn.fhir.model.api.Include( "TestReport:testscript").toLocked(); /** * Search parameter: issued *

* Description: The test report generation date
* Type: date
* Path: TestReport.issued
*

*/ @SearchParamDefinition(name = "issued", path = "TestReport.issued", description = "The test report generation date", type = "date") public static final String SP_ISSUED = "issued"; /** * Fluent Client search parameter constant for issued *

* Description: The test report generation date
* Type: date
* Path: TestReport.issued
*

*/ public static final ca.uhn.fhir.rest.gclient.DateClientParam ISSUED = new ca.uhn.fhir.rest.gclient.DateClientParam( SP_ISSUED); /** * Search parameter: participant *

* Description: The reference to a participant in the test execution
* Type: uri
* Path: TestReport.participant.uri
*

*/ @SearchParamDefinition(name = "participant", path = "TestReport.participant.uri", description = "The reference to a participant in the test execution", type = "uri") public static final String SP_PARTICIPANT = "participant"; /** * Fluent Client search parameter constant for participant *

* Description: The reference to a participant in the test execution
* Type: uri
* Path: TestReport.participant.uri
*

*/ public static final ca.uhn.fhir.rest.gclient.UriClientParam PARTICIPANT = new ca.uhn.fhir.rest.gclient.UriClientParam( SP_PARTICIPANT); }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy