/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
package org.apache.wink.itest.sequence;
import javax.ws.rs.DELETE;
import javax.ws.rs.GET;
import javax.ws.rs.POST;
import javax.ws.rs.Path;
/**
* A singleton resource which keeps track of a constructor, method, and overall
* static count for testing resources called multiple times.
*/
@Path("/singletonsequence")
public class SequenceSingletonResource {
private int hits = 0;
private static int staticHitCount = 0;
private static int constructorHitCount = 0;
public SequenceSingletonResource() {
hits = 0;
++constructorHitCount;
}
@GET
public String countHits() {
return "" + hits;
}
@POST
public String addHit() {
++hits;
++staticHitCount;
return "" + hits;
}
@DELETE
public void clearHits() {
hits = 0;
}
@DELETE
@Path("/static")
public void clearStaticHitCount() {
staticHitCount = 0;
}
@GET
@Path("/static")
public String countStaticHits() {
return "" + staticHitCount;
}
@DELETE
@Path("/constructor")
public void clearConstructorHitCount() {
constructorHitCount = 0;
}
@GET
@Path("/constructor")
public String countConstructorHits() {
return "" + constructorHitCount;
}
}