Author: aidan
Date: Tue Dec  9 09:23:17 2008
New Revision: 724787

URL: http://svn.apache.org/viewvc?rev=724787&view=rev
Log:
QPID-1469: Fix NullPointerException, add test for deleteUser which would expose 
this.

Patch from [EMAIL PROTECTED]

Added:
    
incubator/qpid/trunk/qpid/java/broker/src/test/java/org/apache/qpid/server/security/access/
    
incubator/qpid/trunk/qpid/java/broker/src/test/java/org/apache/qpid/server/security/access/management/
    
incubator/qpid/trunk/qpid/java/broker/src/test/java/org/apache/qpid/server/security/access/management/AMQUserManagementMBeanTest.java
Modified:
    
incubator/qpid/trunk/qpid/java/broker/src/main/java/org/apache/qpid/server/security/access/management/AMQUserManagementMBean.java

Modified: 
incubator/qpid/trunk/qpid/java/broker/src/main/java/org/apache/qpid/server/security/access/management/AMQUserManagementMBean.java
URL: 
http://svn.apache.org/viewvc/incubator/qpid/trunk/qpid/java/broker/src/main/java/org/apache/qpid/server/security/access/management/AMQUserManagementMBean.java?rev=724787&r1=724786&r2=724787&view=diff
==============================================================================
--- 
incubator/qpid/trunk/qpid/java/broker/src/main/java/org/apache/qpid/server/security/access/management/AMQUserManagementMBean.java
 (original)
+++ 
incubator/qpid/trunk/qpid/java/broker/src/main/java/org/apache/qpid/server/security/access/management/AMQUserManagementMBean.java
 Tue Dec  9 09:23:17 2008
@@ -441,7 +441,12 @@
     private String getCurrentJMXUser()
     {
         AccessControlContext acc = AccessController.getContext();
+        
         Subject subject = Subject.getSubject(acc);
+        if (subject == null)
+        {
+            return "Unknown user, authentication Subject was null";
+        }
 
         // Retrieve JMXPrincipal from Subject
         Set<JMXPrincipal> principals = 
subject.getPrincipals(JMXPrincipal.class);

Added: 
incubator/qpid/trunk/qpid/java/broker/src/test/java/org/apache/qpid/server/security/access/management/AMQUserManagementMBeanTest.java
URL: 
http://svn.apache.org/viewvc/incubator/qpid/trunk/qpid/java/broker/src/test/java/org/apache/qpid/server/security/access/management/AMQUserManagementMBeanTest.java?rev=724787&view=auto
==============================================================================
--- 
incubator/qpid/trunk/qpid/java/broker/src/test/java/org/apache/qpid/server/security/access/management/AMQUserManagementMBeanTest.java
 (added)
+++ 
incubator/qpid/trunk/qpid/java/broker/src/test/java/org/apache/qpid/server/security/access/management/AMQUserManagementMBeanTest.java
 Tue Dec  9 09:23:17 2008
@@ -0,0 +1,153 @@
+/*
+ *
+ * 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.qpid.server.security.access.management;
+
+import java.io.BufferedWriter;
+import java.io.File;
+import java.io.FileWriter;
+import java.io.IOException;
+
+import 
org.apache.qpid.server.security.auth.database.Base64MD5PasswordFilePrincipalDatabase;
+
+import junit.framework.TestCase;
+
+public class AMQUserManagementMBeanTest extends TestCase {
+
+       private Base64MD5PasswordFilePrincipalDatabase _database;
+       private AMQUserManagementMBean _amqumMBean;
+
+       private static final String _QPID_HOME =  
System.getProperty("QPID_HOME");
+       
+       private static final String USERNAME = "testuser";
+       private static final String PASSWORD = "password";
+       private static final String JMXRIGHTS = "admin";
+       private static final String TEMP_PASSWORD_FILE_NAME = 
"tempPasswordFile.tmp";
+       private static final String TEMP_JMXACCESS_FILE_NAME = 
"tempJMXAccessFile.tmp";
+
+       @Override
+       protected void setUp() throws Exception {
+
+               assertNotNull("QPID_HOME not set", _QPID_HOME);
+
+               _database = new Base64MD5PasswordFilePrincipalDatabase();
+               _amqumMBean = new AMQUserManagementMBean();
+       }
+       
+       @Override
+       protected void tearDown() throws Exception {
+               
+               File testFile = new File(_QPID_HOME + File.separator + 
TEMP_JMXACCESS_FILE_NAME + ".tmp");
+               if (testFile.exists())
+               {
+                       testFile.delete();
+               }
+               
+               testFile = new File(_QPID_HOME + File.separator + 
TEMP_JMXACCESS_FILE_NAME + ".old");
+               if (testFile.exists())
+               {
+                       testFile.delete();
+               }
+
+               testFile = new File(_QPID_HOME + File.separator + 
TEMP_PASSWORD_FILE_NAME + ".tmp");
+               if (testFile.exists())
+               {
+                       testFile.delete();
+               }
+               
+               testFile = new File(_QPID_HOME + File.separator + 
TEMP_PASSWORD_FILE_NAME + ".old");
+               if (testFile.exists())
+               {
+                       testFile.delete();
+               }
+       }
+
+       public void testDeleteUser() {
+               
+               loadTestPasswordFile();
+               loadTestAccessFile();
+               
+               boolean deleted = false;
+               
+               try{
+                   deleted = _amqumMBean.deleteUser(USERNAME);
+               }
+               catch(Exception e){
+                       fail("Unable to delete user: " + e.getMessage());
+               }
+               
+               assertTrue(deleted);
+       }
+       
+       
+       
+       // ============================ Utility methods 
=========================
+       
+       private void loadTestPasswordFile()
+    {
+               try{
+                       File tempPasswordFile = new File(_QPID_HOME + 
File.separator + TEMP_PASSWORD_FILE_NAME);
+                       if (tempPasswordFile.exists())
+                       {
+                               tempPasswordFile.delete();
+                       }
+                       tempPasswordFile.deleteOnExit();
+
+                       BufferedWriter passwordWriter = new BufferedWriter(new 
FileWriter(tempPasswordFile));
+                       passwordWriter.write(USERNAME + ":" + PASSWORD);
+                       passwordWriter.newLine();
+                       passwordWriter.flush();
+
+
+                       _database.setPasswordFile(tempPasswordFile.toString());
+                       _amqumMBean.setPrincipalDatabase(_database);
+               }
+               catch (IOException e)
+               {
+                       fail("Unable to create test password file: " + 
e.getMessage());
+               }
+    }
+
+       private void loadTestAccessFile()
+    {
+               try{
+                       File tempAccessFile = new File(_QPID_HOME + 
File.separator + TEMP_JMXACCESS_FILE_NAME);
+                       if (tempAccessFile.exists())
+                       {
+                               tempAccessFile.delete();
+                       }
+                       tempAccessFile.deleteOnExit();
+
+                       BufferedWriter accessWriter = new BufferedWriter(new 
FileWriter(tempAccessFile));
+                       accessWriter.write(USERNAME + "=" + JMXRIGHTS);
+                       accessWriter.newLine();
+                       accessWriter.flush();
+
+
+                       _amqumMBean.setAccessFile(tempAccessFile.toString());
+               }       
+               catch (Exception e)
+               {
+                       fail("Unable to create test access file: " + 
e.getMessage());
+               }
+    }
+       
+}


Reply via email to