Coverage for skema/gromet/metadata/gromet_creation.py: 83%
58 statements
« prev ^ index » next coverage.py v7.5.0, created at 2024-04-30 17:15 +0000
« prev ^ index » next coverage.py v7.5.0, created at 2024-04-30 17:15 +0000
1# coding: utf-8
3"""
4 GroMEt Metadata spec
6 Grounded Model Exchange (GroMEt) Metadata schema specification __Using Swagger to Generate Class Structure__ To automatically generate Python or Java models corresponding to this document, you can use [swagger-codegen](https://swagger.io/tools/swagger-codegen/). We can use this to generate client code based off of this spec that will also generate the class structure. 1. Install via the method described for your operating system [here](https://github.com/swagger-api/swagger-codegen#Prerequisites). Make sure to install a version after 3.0 that will support openapi 3. 2. Run swagger-codegen with the options in the example below. The URL references where the yaml for this documentation is stored on github. Make sure to replace CURRENT_VERSION with the correct version. (The current version is `0.1.4`.) To generate Java classes rather, change the `-l python` to `-l java`. Change the value to the `-o` option to the desired output location. ``` swagger-codegen generate -l python -o ./client -i https://raw.githubusercontent.com/ml4ai/automates-v2/master/docs/source/gromet_metadata_v{CURRENT_VERSION}.yaml ``` 3. Once it executes, the client code will be generated at your specified location. For python, the classes will be located in `$OUTPUT_PATH/swagger_client/models/`. For java, they will be located in `$OUTPUT_PATH/src/main/java/io/swagger/client/model/` If generating GroMEt Metadata schema data model classes in SKEMA (AutoMATES), then after generating the above, follow the instructions here: ``` <automates>/automates/model_assembly/gromet/metadata/README.md ``` # noqa: E501
8 OpenAPI spec version: 0.1.8
9 Contact: claytonm@arizona.edu
10 Generated by: https://github.com/swagger-api/swagger-codegen.git
11"""
13import pprint
14import re # noqa: F401
16import six
17from skema.gromet.metadata.metadata import Metadata # noqa: F401,E501
19class GrometCreation(Metadata):
20 """NOTE: This class is auto generated by the swagger code generator program.
22 Do not edit the class manually.
23 """
24 """
25 Attributes:
26 swagger_types (dict): The key is attribute name
27 and the value is attribute type.
28 attribute_map (dict): The key is attribute name
29 and the value is json key in definition.
30 """
31 swagger_types = {
32 'gromet_type': 'str',
33 'gromet_version': 'str'
34 }
35 if hasattr(Metadata, "swagger_types"):
36 swagger_types.update(Metadata.swagger_types)
38 attribute_map = {
39 'gromet_type': 'gromet_type',
40 'gromet_version': 'gromet_version'
41 }
42 if hasattr(Metadata, "attribute_map"):
43 attribute_map.update(Metadata.attribute_map)
45 def __init__(self, gromet_type='GrometCreation', gromet_version='0.1.2', *args, **kwargs): # noqa: E501
46 """GrometCreation - a model defined in Swagger""" # noqa: E501
47 self._gromet_type = None
48 self._gromet_version = None
49 self.discriminator = None
50 if gromet_type is not None:
51 self.gromet_type = gromet_type
52 if gromet_version is not None:
53 self.gromet_version = gromet_version
54 Metadata.__init__(self, *args, **kwargs)
56 @property
57 def gromet_type(self):
58 """Gets the gromet_type of this GrometCreation. # noqa: E501
61 :return: The gromet_type of this GrometCreation. # noqa: E501
62 :rtype: str
63 """
64 return self._gromet_type
66 @gromet_type.setter
67 def gromet_type(self, gromet_type):
68 """Sets the gromet_type of this GrometCreation.
71 :param gromet_type: The gromet_type of this GrometCreation. # noqa: E501
72 :type: str
73 """
75 self._gromet_type = gromet_type
77 @property
78 def gromet_version(self):
79 """Gets the gromet_version of this GrometCreation. # noqa: E501
82 :return: The gromet_version of this GrometCreation. # noqa: E501
83 :rtype: str
84 """
85 return self._gromet_version
87 @gromet_version.setter
88 def gromet_version(self, gromet_version):
89 """Sets the gromet_version of this GrometCreation.
92 :param gromet_version: The gromet_version of this GrometCreation. # noqa: E501
93 :type: str
94 """
96 self._gromet_version = gromet_version
98 def to_dict(self):
99 """Returns the model properties as a dict"""
100 result = {}
102 for attr, _ in six.iteritems(self.swagger_types):
103 value = getattr(self, attr)
104 if isinstance(value, list):
105 result[attr] = list(map(
106 lambda x: x.to_dict() if hasattr(x, "to_dict") else x,
107 value
108 ))
109 elif hasattr(value, "to_dict"):
110 result[attr] = value.to_dict()
111 elif isinstance(value, dict):
112 result[attr] = dict(map(
113 lambda item: (item[0], item[1].to_dict())
114 if hasattr(item[1], "to_dict") else item,
115 value.items()
116 ))
117 else:
118 result[attr] = value
119 if issubclass(GrometCreation, dict):
120 for key, value in self.items():
121 result[key] = value
123 return result
125 def to_str(self):
126 """Returns the string representation of the model"""
127 return pprint.pformat(self.to_dict())
129 def __repr__(self):
130 """For `print` and `pprint`"""
131 return self.to_str()
133 def __eq__(self, other):
134 """Returns true if both objects are equal"""
135 if not isinstance(other, GrometCreation):
136 return False
138 return self.__dict__ == other.__dict__
140 def __ne__(self, other):
141 """Returns true if both objects are not equal"""
142 return not self == other