blob: 118e726a914f2b21a58e454badd8d424eb60de22 [file] [log] [blame]
/*
* Copyright (c) 1997, 2018 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 test;
import jakarta.servlet.ServletContext;
import jakarta.servlet.ServletContextListener;
import jakarta.servlet.ServletContextEvent;
import javax.naming.*;
import jakarta.annotation.Resource;
import jakarta.annotation.Resources;
import javax.sql.DataSource;
@Resource(name="myDataSource4", type=DataSource.class)
@Resources({ @Resource(name="myDataSource5", type=DataSource.class),
@Resource(name="jdbc/myDataSource6", type=DataSource.class) })
public class MyListener implements ServletContextListener {
private @Resource DataSource ds1;
private @Resource(name="myDataSource2") DataSource ds2;
private DataSource ds3;
@Resource(name="jdbc/myDataSource3")
private void setDataSource(DataSource ds) {
ds3 = ds;
}
/**
* Receives notification that the web application initialization
* process is starting.
*
* @param sce The servlet context event
*/
public void contextInitialized(ServletContextEvent sce) {
ServletContext sc = sce.getServletContext();
try {
int loginTimeout = ds1.getLoginTimeout();
sc.log("ds1-login-timeout=" + loginTimeout);
loginTimeout = ds2.getLoginTimeout();
sc.log(",ds2-login-timeout=" + loginTimeout);
loginTimeout = ds3.getLoginTimeout();
sc.log(",ds3-login-timeout=" + loginTimeout);
InitialContext ic = new InitialContext();
DataSource ds4 = (DataSource)
ic.lookup("java:comp/env/myDataSource4");
loginTimeout = ds4.getLoginTimeout();
sc.log(",ds4-login-timeout=" + loginTimeout);
DataSource ds5 = (DataSource)
ic.lookup("java:comp/env/myDataSource5");
loginTimeout = ds5.getLoginTimeout();
sc.log(",ds5-login-timeout=" + loginTimeout);
DataSource ds6 = (DataSource)
ic.lookup("java:comp/env/jdbc/myDataSource6");
loginTimeout = ds6.getLoginTimeout();
sc.log(",ds6-login-timeout=" + loginTimeout);
sc.setAttribute("success", new Object());
} catch (Exception e) {
throw new RuntimeException(e);
}
}
/**
* Receives notification that the servlet context is about to be shut down.
*
* @param sce The servlet context event
*/
public void contextDestroyed(ServletContextEvent sce) {
// Do nothing
}
}