diff --git a/api/src/main/java/jakarta/mail/Folder.java b/api/src/main/java/jakarta/mail/Folder.java index d245c8fa..a627e7ba 100644 --- a/api/src/main/java/jakarta/mail/Folder.java +++ b/api/src/main/java/jakarta/mail/Folder.java @@ -103,7 +103,6 @@ public abstract class Folder implements AutoCloseable { - private final AtomicBoolean closed = new AtomicBoolean(false); /** * The parent store. */ @@ -652,12 +651,14 @@ public abstract boolean delete(boolean recurse) */ @Override public void close() throws MessagingException { - if (!closed.getAndSet(true)) { - try { - close(true); - } finally { - q.terminateQueue(); + try { + close(true); + } catch (IllegalStateException ise) { + if (isOpen()) { + throw ise; } + } finally { + q.terminateQueue(); } } diff --git a/api/src/test/java/jakarta/mail/FolderTest.java b/api/src/test/java/jakarta/mail/FolderTest.java deleted file mode 100644 index b7bbfe3b..00000000 --- a/api/src/test/java/jakarta/mail/FolderTest.java +++ /dev/null @@ -1,163 +0,0 @@ -/* - * Copyright (c) 2024 Oracle and/or its affiliates. All rights reserved. - * - * This program and the accompanying materials are made available under the - * terms of the Eclipse Public License v. 2.0, which is available at - * http://www.eclipse.org/legal/epl-2.0. - * - * This Source Code may also be made available under the following Secondary - * Licenses when the conditions for such availability set forth in the - * Eclipse Public License v. 2.0 are satisfied: GNU General Public License, - * version 2 with the GNU Classpath Exception, which is available at - * https://www.gnu.org/software/classpath/license.html. - * - * SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0 - */ - -package jakarta.mail; - -import static org.junit.Assert.assertEquals; - -import java.util.Properties; - -import org.junit.Test; - -public class FolderTest { - - @Test - public void closeIdempotent() throws MessagingException { - CustomFolder folder = new CustomFolder(new DummyStore(Session.getDefaultInstance(new Properties()), null)); - folder.close(); - folder.close(); - assertEquals(1, folder.closedTimes); - } - - private static class CustomFolder extends Folder { - - private int closedTimes = 0; - - protected CustomFolder(Store store) { - super(store); - } - - @Override - public String getName() { - return null; - } - - @Override - public String getFullName() { - return null; - } - - @Override - public Folder getParent() throws MessagingException { - return null; - } - - @Override - public boolean exists() throws MessagingException { - return false; - } - - @Override - public Folder[] list(String pattern) throws MessagingException { - return null; - } - - @Override - public char getSeparator() throws MessagingException { - return 0; - } - - @Override - public int getType() throws MessagingException { - return 0; - } - - @Override - public boolean create(int type) throws MessagingException { - return false; - } - - @Override - public boolean hasNewMessages() throws MessagingException { - return false; - } - - @Override - public Folder getFolder(String name) throws MessagingException { - return null; - } - - @Override - public boolean delete(boolean recurse) throws MessagingException { - return false; - } - - @Override - public boolean renameTo(Folder f) throws MessagingException { - return false; - } - - @Override - public void open(int mode) throws MessagingException { - } - - @Override - public void close(boolean expunge) throws MessagingException { - closedTimes++; - } - - @Override - public boolean isOpen() { - return false; - } - - @Override - public Flags getPermanentFlags() { - return null; - } - - @Override - public int getMessageCount() throws MessagingException { - return 0; - } - - @Override - public Message getMessage(int msgnum) throws MessagingException { - return null; - } - - @Override - public void appendMessages(Message[] msgs) throws MessagingException { - } - - @Override - public Message[] expunge() throws MessagingException { - return null; - } - } - - private static class DummyStore extends Store { - - protected DummyStore(Session session, URLName urlname) { - super(session, urlname); - } - - @Override - public Folder getDefaultFolder() throws MessagingException { - return null; - } - - @Override - public Folder getFolder(String name) throws MessagingException { - return null; - } - - @Override - public Folder getFolder(URLName url) throws MessagingException { - return null; - } - } -}