
com.codepine.api.testrail.model.Case Maven / Gradle / Ivy
The newest version!
/*
* The MIT License (MIT)
*
* Copyright (c) 2015 Kunal Shah
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in all
* copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
*/
package com.codepine.api.testrail.model;
import com.codepine.api.testrail.TestRail;
import com.fasterxml.jackson.annotation.JsonAnyGetter;
import com.fasterxml.jackson.annotation.JsonAnySetter;
import com.fasterxml.jackson.annotation.JsonIgnore;
import com.fasterxml.jackson.annotation.JsonView;
import com.fasterxml.jackson.core.JsonGenerationException;
import com.fasterxml.jackson.core.JsonGenerator;
import com.fasterxml.jackson.databind.SerializerProvider;
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
import com.fasterxml.jackson.databind.ser.std.StdKeySerializer;
import com.google.common.base.MoreObjects;
import lombok.Data;
import java.io.IOException;
import java.util.Collections;
import java.util.Date;
import java.util.HashMap;
import java.util.Map;
import static com.codepine.api.testrail.model.Field.Type;
/**
* TestRail case.
*/
@Data
public class Case {
private static final String CUSTOM_FIELD_KEY_PREFIX = "custom_";
private int id;
@JsonView({TestRail.Cases.Add.class, TestRail.Cases.Update.class})
private String title;
@JsonView({TestRail.Cases.Add.class, TestRail.Cases.Update.class})
private Integer templateId;
private int sectionId;
@JsonView({TestRail.Cases.Add.class, TestRail.Cases.Update.class})
private Integer typeId;
@JsonView({TestRail.Cases.Add.class, TestRail.Cases.Update.class})
private Integer priorityId;
@JsonView({TestRail.Cases.Add.class, TestRail.Cases.Update.class})
private Integer milestoneId;
@JsonView({TestRail.Cases.Add.class, TestRail.Cases.Update.class})
private String refs;
private int createdBy;
private Date createdOn;
private int updatedBy;
private Date updatedOn;
@JsonView({TestRail.Cases.Add.class, TestRail.Cases.Update.class})
private String estimate;
private String estimateForecast;
private int suiteId;
@JsonView({TestRail.Cases.Add.class, TestRail.Cases.Update.class})
@JsonIgnore
private Map customFields;
@JsonAnyGetter
@JsonSerialize(keyUsing = CustomFieldSerializer.class)
public Map getCustomFields() {
return MoreObjects.firstNonNull(customFields, Collections.emptyMap());
}
/**
* Add a custom field.
*
* @param key the name of the custom field with or without "custom_" prefix
* @param value the value of the custom field
* @return case instance for chaining
*/
public Case addCustomField(String key, Object value) {
if (customFields == null) {
customFields = new HashMap<>();
}
customFields.put(key.replaceFirst(CUSTOM_FIELD_KEY_PREFIX, ""), value);
return this;
}
/**
* Support for forward compatibility and extracting custom fields.
*
* @param key the name of the unknown field
* @param value the value of the unkown field
*/
@JsonAnySetter
private void addUnknownField(String key, Object value) {
if (key.startsWith(CUSTOM_FIELD_KEY_PREFIX)) {
addCustomField(key, value);
}
}
/**
* Get custom field.
* Use Java Type Inference, to get the value with correct type. Refer to {@link Type} for a map of TestRail field types to Java types.
*
* @param key the system name of custom field
* @param the type of returned value
* @return the value of the custom field
*/
public T getCustomField(String key) {
return (T) getCustomFields().get(key);
}
/**
* Serializer for custom fields.
*/
private static class CustomFieldSerializer extends StdKeySerializer {
@Override
public void serialize(Object o, JsonGenerator jsonGenerator, SerializerProvider serializerProvider) throws IOException, JsonGenerationException {
super.serialize(CUSTOM_FIELD_KEY_PREFIX + o, jsonGenerator, serializerProvider);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy