1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105
|
import unittest
from p4vasp.Structure import *
from StringIO import *
class TestStructure(unittest.TestCase):
def testParsingCell(self):
f=StringIO("""test chgcar
1
1 2 3
4 5 6
7 8 9
1
cart
0 0 0
""")
s=Structure()
s.read(f)
self.assertEquals(s.basis[0][0],1)
self.assertEquals(s.basis[0][1],2)
self.assertEquals(s.basis[0][2],3)
self.assertEquals(s.basis[1][0],4)
self.assertEquals(s.basis[1][1],5)
self.assertEquals(s.basis[1][2],6)
self.assertEquals(s.basis[2][0],7)
self.assertEquals(s.basis[2][1],8)
self.assertEquals(s.basis[2][2],9)
def testReciprocalLattice(self):
f=StringIO("""test chgcar
1
0 10 10
10 0 10
10 10 0
1
cart
0 0 0
""")
s=Structure()
s.read(f)
s.updateRecipBasis()
self.assertEquals(s.rbasis[0][0],-0.05)
self.assertEquals(s.rbasis[0][1],0.05)
self.assertEquals(s.rbasis[0][2],0.05)
self.assertEquals(s.rbasis[1][0],0.05)
self.assertEquals(s.rbasis[1][1],-0.05)
self.assertEquals(s.rbasis[1][2],0.05)
self.assertEquals(s.rbasis[2][0],0.05)
self.assertEquals(s.rbasis[2][1],0.05)
self.assertEquals(s.rbasis[2][2],-0.05)
def testAppendAtom(self):
s=Structure()
self.assertEquals(len(s.info),0)
self.assertEquals(len(s.positions),0)
s.appendAtom(0,(1,2,3))
self.assertEquals(len(s.info),1)
self.assertEquals(len(s.positions),1)
self.assertEquals(s[0][0],1)
self.assertEquals(s[0][1],2)
self.assertEquals(s[0][2],3)
s.appendAtom(1,(4,5,6))
self.assertEquals(len(s.info),2)
self.assertEquals(len(s.positions),2)
self.assertEquals(s[1][0],4)
self.assertEquals(s[1][1],5)
self.assertEquals(s[1][2],6)
s.appendAtom(0,(7,8,9))
self.assertEquals(len(s.info),2)
self.assertEquals(len(s.positions),3)
self.assertEquals(s[0][0],1)
self.assertEquals(s[0][1],2)
self.assertEquals(s[0][2],3)
self.assertEquals(s[1][0],7)
self.assertEquals(s[1][1],8)
self.assertEquals(s[1][2],9)
self.assertEquals(s[2][0],4)
self.assertEquals(s[2][1],5)
self.assertEquals(s[2][2],6)
def testNewSpecie(self):
s=Structure()
self.assertEquals(len(s.info),0)
self.assertEquals(len(s.positions),0)
s.appendAtomOfNewSpecie((1,2,3))
self.assertEquals(len(s.info),1)
self.assertEquals(len(s.positions),1)
self.assertEquals(s[0][0],1)
self.assertEquals(s[0][1],2)
self.assertEquals(s[0][2],3)
s.appendAtomOfNewSpecie((4,5,6))
self.assertEquals(len(s.info),2)
self.assertEquals(len(s.positions),2)
self.assertEquals(s[0][0],1)
self.assertEquals(s[0][1],2)
self.assertEquals(s[0][2],3)
self.assertEquals(s[1][0],4)
self.assertEquals(s[1][1],5)
self.assertEquals(s[1][2],6)
if __name__ == '__main__':
unittest.main()
|