Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
101 changes: 101 additions & 0 deletions gmail/snippets/src/main/java/ListMessages.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,101 @@
// Copyright 2026 Google LLC
//
// Licensed 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
//
// https://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.

// [START gmail_list_messages]

import com.google.api.client.googleapis.javanet.GoogleNetHttpTransport;
import com.google.api.client.googleapis.json.GoogleJsonResponseException;
import com.google.api.client.http.HttpRequestInitializer;
import com.google.api.client.json.gson.GsonFactory;
import com.google.api.services.gmail.Gmail;
import com.google.api.services.gmail.GmailScopes;
import com.google.api.services.gmail.model.ListMessagesResponse;
import com.google.api.services.gmail.model.Message;
import com.google.auth.http.HttpCredentialsAdapter;
import com.google.auth.oauth2.GoogleCredentials;

import java.io.IOException;
import java.security.GeneralSecurityException;
import java.util.Collections;
import java.util.List;

/*
* Class to demonstrate the use of Gmail List Messages API
*/
public class ListMessages {

/**
* Lists the user's Gmail messages.
*
* @param service Authorized Gmail API instance.
* @return List of Messages in the user's mailbox.
* @throws IOException if the request to retrieve messages fails.
* @throws GoogleJsonResponseException if the execution of the request fails.
*/
public static List<Message> listMessages(Gmail service) throws IOException {

try {
final long maxMessages = 10L;
final String userId = "me";
ListMessagesResponse results =
service
.users()
.messages()
.list(userId)
.setLabelIds(Collections.singletonList("INBOX"))
.setMaxResults(maxMessages)
.execute();

List<Message> messages = results.getMessages();

if (messages == null || messages.isEmpty()) {
System.out.println("No messages found.");
return messages;
}

System.out.println("Messages:");
for (Message message : messages) {
/*TODO(developer) - Consider batch requests if you need to retrieve many messages at once.
See https://developers.google.com/workspace/gmail/api/guides/batch for implementation guides. */
Message msg = service.users().messages().get(userId, message.getId()).execute();

System.out.printf("- Message ID: %s%n Snippet: %s%n", message.getId(), msg.getSnippet());
}
return messages;
} catch (GoogleJsonResponseException e) {
// TODO(developer) - handle error appropriately
System.err.println("An error occurred: " + e);
throw e;
}
}

private static Gmail getGmailService() throws IOException, GeneralSecurityException {
/* Load pre-authorized user credentials from the environment.
TODO(developer) - See https://developers.google.com/identity for
guides on implementing OAuth2 for your application. */
GoogleCredentials credentials =
GoogleCredentials.getApplicationDefault().createScoped(GmailScopes.GMAIL_READONLY);
HttpRequestInitializer requestInitializer = new HttpCredentialsAdapter(credentials);

// Create the gmail API client
return new Gmail.Builder(
GoogleNetHttpTransport.newTrustedTransport(),
GsonFactory.getDefaultInstance(),
requestInitializer)
.setApplicationName("Gmail samples")
.build();
}
}

// [END gmail_list_messages]
130 changes: 130 additions & 0 deletions gmail/snippets/src/test/java/TestListMessages.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,130 @@
// Copyright 2026 Google LLC
//
// Licensed 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
//
// https://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.

import com.google.api.client.googleapis.json.GoogleJsonResponseException;
import com.google.api.client.http.HttpTransport;
import com.google.api.client.http.LowLevelHttpRequest;
import com.google.api.client.http.LowLevelHttpResponse;
import com.google.api.client.json.Json;
import com.google.api.client.json.gson.GsonFactory;
import com.google.api.client.testing.http.MockHttpTransport;
import com.google.api.client.testing.http.MockLowLevelHttpRequest;
import com.google.api.client.testing.http.MockLowLevelHttpResponse;
import com.google.api.services.gmail.Gmail;
import com.google.api.services.gmail.model.Message;
import org.junit.Test;

import java.io.IOException;
import java.util.List;

import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertThrows;
import static org.junit.Assert.assertTrue;

// Unit test case for gmail list messages snippet
public class TestListMessages {

@Test
public void testListMessagesReturnsMessages() throws IOException {
HttpTransport transport =
new MockHttpTransport() {
@Override
public LowLevelHttpRequest buildRequest(String method, String url) {
return new MockLowLevelHttpRequest() {
@Override
public LowLevelHttpResponse execute() {
MockLowLevelHttpResponse response = new MockLowLevelHttpResponse();
response.setStatusCode(200);
response.setContentType(Json.MEDIA_TYPE);

// Mock response for listing messages in the inbox
if (url.contains("/messages") && url.contains("labelIds=INBOX")) {
response.setContent("{\"messages\": [{\"id\": \"12345\"}]}");
} else if (url.contains("/messages/12345")) {
response.setContent(
"{\"id\": \"12345\", \"snippet\": \"This is a test snippet.\"}");
} else {
response.setStatusCode(404);
}
return response;
}
};
}
};

Gmail service = getMockGmailService(transport);
List<Message> result = ListMessages.listMessages(service);

assertNotNull("The returned message list should not be null", result);
assertEquals("The returned list should contain exactly one message", 1, result.size());
assertEquals("The message ID should match the mock data", "12345", result.get(0).getId());
}

@Test
public void testListMessagesHandlesApiError() {
// Mock transport simulates a 404 Not Found error
HttpTransport errorTransport =
new MockHttpTransport() {
@Override
public LowLevelHttpRequest buildRequest(String method, String url) {
return new MockLowLevelHttpRequest() {
@Override
public LowLevelHttpResponse execute() {
MockLowLevelHttpResponse response = new MockLowLevelHttpResponse();
response.setStatusCode(404);
response.setContentType(Json.MEDIA_TYPE);
response.setContent("{\"error\": {\"code\": 404, \"message\": \"Not Found\"}}");
return response;
}
};
}
};

Gmail service = getMockGmailService(errorTransport);
assertThrows(GoogleJsonResponseException.class, () -> ListMessages.listMessages(service));
}

@Test
public void testListMessagesHandlesEmptyResults() throws IOException {
// Mock transport returns empty messages array
HttpTransport emptyTransport =
new MockHttpTransport() {
@Override
public LowLevelHttpRequest buildRequest(String method, String url) {
return new MockLowLevelHttpRequest() {
@Override
public LowLevelHttpResponse execute() {
MockLowLevelHttpResponse response = new MockLowLevelHttpResponse();
response.setStatusCode(200);
response.setContentType(Json.MEDIA_TYPE);
response.setContent("{\"messages\": []}");
return response;
}
};
}
};

Gmail service = getMockGmailService(emptyTransport);
List<Message> result = ListMessages.listMessages(service);
assertNotNull("Should return an empty list when no messages found", result);
assertTrue("Returned list should be empty", result.isEmpty());
}

private Gmail getMockGmailService(HttpTransport transport) {
return new Gmail.Builder(transport, GsonFactory.getDefaultInstance(), request -> {})
.setApplicationName("Gmail API Snippets")
.build();
}
}