Author: rwinston
Date: Fri Apr 15 09:50:48 2005
New Revision: 161506

URL: http://svn.apache.org/viewcvs?view=rev&rev=161506
Log:
Added to repository

Added:
    
jakarta/commons/proper/net/trunk/src/test/org/apache/commons/net/ftp/parser/FTPConfigEntryParserTest.java

Added: 
jakarta/commons/proper/net/trunk/src/test/org/apache/commons/net/ftp/parser/FTPConfigEntryParserTest.java
URL: 
http://svn.apache.org/viewcvs/jakarta/commons/proper/net/trunk/src/test/org/apache/commons/net/ftp/parser/FTPConfigEntryParserTest.java?view=auto&rev=161506
==============================================================================
--- 
jakarta/commons/proper/net/trunk/src/test/org/apache/commons/net/ftp/parser/FTPConfigEntryParserTest.java
 (added)
+++ 
jakarta/commons/proper/net/trunk/src/test/org/apache/commons/net/ftp/parser/FTPConfigEntryParserTest.java
 Fri Apr 15 09:50:48 2005
@@ -0,0 +1,148 @@
+package org.apache.commons.net.ftp.parser;
+
+import java.text.SimpleDateFormat;
+import java.util.Calendar;
+import java.util.Date;
+
+import junit.framework.TestCase;
+
+import org.apache.commons.net.ftp.FTPClientConfig;
+import org.apache.commons.net.ftp.FTPFile;
+
+/**
+ * This is a simple TestCase that tests entry parsing using the new 
FTPClientConfig
+ * mechanism. The normal FTPClient cannot handle the different date format in 
these 
+ * entries, however using a configurable format, we can handle it easily.
+ * 
+ * The original system presenting this issue was an AIX system - see bug 
#27437 for details.
+ * 
+ *  $Id$
+ */
+public class FTPConfigEntryParserTest extends TestCase {
+       
+       private SimpleDateFormat df = new SimpleDateFormat();
+
+       public void testParseFieldsOnAIX() {
+               
+               // Set a date format for this server type
+               FTPClientConfig config = new 
FTPClientConfig(FTPClientConfig.SYST_UNIX);
+               config.setDefaultDateFormatStr("dd MMM HH:mm");
+
+               UnixFTPEntryParser parser = new UnixFTPEntryParser();
+               parser.configure(config);
+
+               FTPFile f = parser.parseFTPEntry("-rw-r-----   1 ravensm  sca   
       814 02 Mar 16:27 ZMIR2.m");
+
+               assertNotNull("Could not parse entry.", f);
+               assertFalse("Is not a directory.", f.isDirectory());
+
+               assertTrue("Should have user read permission.", f.hasPermission(
+                               FTPFile.USER_ACCESS, FTPFile.READ_PERMISSION));
+               assertTrue("Should have user write permission.", 
f.hasPermission(
+                               FTPFile.USER_ACCESS, FTPFile.WRITE_PERMISSION));
+               assertFalse("Should NOT have user execute permission.", f
+                               .hasPermission(FTPFile.USER_ACCESS, 
FTPFile.EXECUTE_PERMISSION));
+               assertTrue("Should have group read permission.", 
f.hasPermission(
+                               FTPFile.GROUP_ACCESS, FTPFile.READ_PERMISSION));
+               assertFalse("Should NOT have group write permission.", f
+                               .hasPermission(FTPFile.GROUP_ACCESS, 
FTPFile.WRITE_PERMISSION));
+               assertFalse("Should NOT have group execute permission.",
+                               f.hasPermission(FTPFile.GROUP_ACCESS,
+                                               FTPFile.EXECUTE_PERMISSION));
+               assertFalse("Should NOT have world read permission.", 
f.hasPermission(
+                               FTPFile.WORLD_ACCESS, FTPFile.READ_PERMISSION));
+               assertFalse("Should NOT have world write permission.", f
+                               .hasPermission(FTPFile.WORLD_ACCESS, 
FTPFile.WRITE_PERMISSION));
+               assertFalse("Should NOT have world execute permission.",
+                               f.hasPermission(FTPFile.WORLD_ACCESS,
+                                               FTPFile.EXECUTE_PERMISSION));
+
+               assertEquals(1, f.getHardLinkCount());
+
+               assertEquals("ravensm", f.getUser());
+               assertEquals("sca", f.getGroup());
+
+               assertEquals("ZMIR2.m", f.getName());
+               assertEquals(814, f.getSize());
+
+               Calendar cal = Calendar.getInstance();
+               
+               Date refDate = new Date();
+               
+               cal.set(Calendar.MONTH, Calendar.MARCH);
+               cal.set(Calendar.DATE, 2);
+               cal.set(Calendar.HOUR_OF_DAY, 16);
+               cal.set(Calendar.MINUTE, 27);
+               cal.set(Calendar.SECOND, 0);
+               
+               // With no year specified, it defaults to 1970
+               // TODO this is a bug - it should default to the current year
+               cal.set(Calendar.YEAR, 1970);
+               
+               assertEquals(df.format(cal.getTime()), 
df.format(f.getTimestamp()
+                               .getTime()));
+       }
+       
+       /**
+        * This is a new format reported on the mailing lists. Parsing this 
kind of 
+        * entry necessitated changing the regex in the parser.
+        *
+        */
+       public void testParseEntryWithSymlink() {
+               
+               FTPClientConfig config = new 
FTPClientConfig(FTPClientConfig.SYST_UNIX);
+               config.setDefaultDateFormatStr("yyyy-MM-dd HH:mm");
+
+               UnixFTPEntryParser parser = new UnixFTPEntryParser();
+               parser.configure(config);
+
+               FTPFile f = parser.parseFTPEntry("lrwxrwxrwx   1 neeme neeme    
23 2005-03-02 18:06 macros");
+
+               assertNotNull("Could not parse entry.", f);
+               assertFalse("Is not a directory.", f.isDirectory());
+               assertTrue("Is a symbolic link", f.isSymbolicLink());
+
+               assertTrue("Should have user read permission.", f.hasPermission(
+                               FTPFile.USER_ACCESS, FTPFile.READ_PERMISSION));
+               assertTrue("Should have user write permission.", 
f.hasPermission(
+                               FTPFile.USER_ACCESS, FTPFile.WRITE_PERMISSION));
+               assertTrue("Should have user execute permission.", f
+                               .hasPermission(FTPFile.USER_ACCESS, 
FTPFile.EXECUTE_PERMISSION));
+               assertTrue("Should have group read permission.", 
f.hasPermission(
+                               FTPFile.GROUP_ACCESS, FTPFile.READ_PERMISSION));
+               assertTrue("Should have group write permission.", f
+                               .hasPermission(FTPFile.GROUP_ACCESS, 
FTPFile.WRITE_PERMISSION));
+               assertTrue("Should have group execute permission.",
+                               f.hasPermission(FTPFile.GROUP_ACCESS, 
FTPFile.EXECUTE_PERMISSION));
+               assertTrue("Should have world read permission.", 
f.hasPermission(
+                               FTPFile.WORLD_ACCESS, FTPFile.READ_PERMISSION));
+               assertTrue("Should have world write permission.", f
+                               .hasPermission(FTPFile.WORLD_ACCESS, 
FTPFile.WRITE_PERMISSION));
+               assertTrue("Should have world execute permission.",
+                               f.hasPermission(FTPFile.WORLD_ACCESS, 
FTPFile.EXECUTE_PERMISSION));
+
+               assertEquals(1, f.getHardLinkCount());
+
+               assertEquals("neeme", f.getUser());
+               assertEquals("neeme", f.getGroup());
+
+               assertEquals("macros", f.getName());
+               assertEquals(23, f.getSize());
+
+               Calendar cal = Calendar.getInstance();
+               
+               Date refDate = new Date();
+               
+               cal.set(Calendar.MONTH, Calendar.MARCH);
+               cal.set(Calendar.DATE, 2);
+               cal.set(Calendar.HOUR_OF_DAY, 18);
+               cal.set(Calendar.MINUTE, 06);
+               cal.set(Calendar.SECOND, 0);
+               cal.set(Calendar.YEAR, 2005);
+                       
+               assertEquals(df.format(cal.getTime()), 
df.format(f.getTimestamp()
+                               .getTime()));
+               
+       }
+
+}
\ No newline at end of file



---------------------------------------------------------------------
To unsubscribe, e-mail: [EMAIL PROTECTED]
For additional commands, e-mail: [EMAIL PROTECTED]

Reply via email to