001/*-
002 * #%L
003 * HAPI FHIR - Core Library
004 * %%
005 * Copyright (C) 2014 - 2025 Smile CDR, Inc.
006 * %%
007 * Licensed under the Apache License, Version 2.0 (the "License");
008 * you may not use this file except in compliance with the License.
009 * You may obtain a copy of the License at
010 *
011 *      http://www.apache.org/licenses/LICENSE-2.0
012 *
013 * Unless required by applicable law or agreed to in writing, software
014 * distributed under the License is distributed on an "AS IS" BASIS,
015 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
016 * See the License for the specific language governing permissions and
017 * limitations under the License.
018 * #L%
019 */
020package ca.uhn.fhir.util;
021
022/**
023 * A utility class for thread sleeps.
024 * Uses non-static methods for easier mocking and unnecessary waits in unit tests
025 */
026public class SleepUtil {
027        private static final org.slf4j.Logger ourLog = org.slf4j.LoggerFactory.getLogger(SleepUtil.class);
028
029        public void sleepAtLeast(long theMillis) {
030                sleepAtLeast(theMillis, true);
031        }
032
033        @SuppressWarnings("BusyWait")
034        public void sleepAtLeast(long theMillis, boolean theLogProgress) {
035                long start = System.currentTimeMillis();
036                while (System.currentTimeMillis() < start + theMillis) {
037                        try {
038                                long timeSinceStarted = System.currentTimeMillis() - start;
039                                long timeToSleep = Math.max(0, theMillis - timeSinceStarted);
040                                if (theLogProgress) {
041                                        ourLog.info("Sleeping for {}ms", timeToSleep);
042                                }
043                                Thread.sleep(timeToSleep);
044                        } catch (InterruptedException e) {
045                                Thread.currentThread().interrupt();
046                                ourLog.error("Interrupted", e);
047                        }
048                }
049        }
050}