tcparser.pas 297 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952295329542955295629572958295929602961296229632964296529662967296829692970297129722973297429752976297729782979298029812982298329842985298629872988298929902991299229932994299529962997299829993000300130023003300430053006300730083009301030113012301330143015301630173018301930203021302230233024302530263027302830293030303130323033303430353036303730383039304030413042304330443045304630473048304930503051305230533054305530563057305830593060306130623063306430653066306730683069307030713072307330743075307630773078307930803081308230833084308530863087308830893090309130923093309430953096309730983099310031013102310331043105310631073108310931103111311231133114311531163117311831193120312131223123312431253126312731283129313031313132313331343135313631373138313931403141314231433144314531463147314831493150315131523153315431553156315731583159316031613162316331643165316631673168316931703171317231733174317531763177317831793180318131823183318431853186318731883189319031913192319331943195319631973198319932003201320232033204320532063207320832093210321132123213321432153216321732183219322032213222322332243225322632273228322932303231323232333234323532363237323832393240324132423243324432453246324732483249325032513252325332543255325632573258325932603261326232633264326532663267326832693270327132723273327432753276327732783279328032813282328332843285328632873288328932903291329232933294329532963297329832993300330133023303330433053306330733083309331033113312331333143315331633173318331933203321332233233324332533263327332833293330333133323333333433353336333733383339334033413342334333443345334633473348334933503351335233533354335533563357335833593360336133623363336433653366336733683369337033713372337333743375337633773378337933803381338233833384338533863387338833893390339133923393339433953396339733983399340034013402340334043405340634073408340934103411341234133414341534163417341834193420342134223423342434253426342734283429343034313432343334343435343634373438343934403441344234433444344534463447344834493450345134523453345434553456345734583459346034613462346334643465346634673468346934703471347234733474347534763477347834793480348134823483348434853486348734883489349034913492349334943495349634973498349935003501350235033504350535063507350835093510351135123513351435153516351735183519352035213522352335243525352635273528352935303531353235333534353535363537353835393540354135423543354435453546354735483549355035513552355335543555355635573558355935603561356235633564356535663567356835693570357135723573357435753576357735783579358035813582358335843585358635873588358935903591359235933594359535963597359835993600360136023603360436053606360736083609361036113612361336143615361636173618361936203621362236233624362536263627362836293630363136323633363436353636363736383639364036413642364336443645364636473648364936503651365236533654365536563657365836593660366136623663366436653666366736683669367036713672367336743675367636773678367936803681368236833684368536863687368836893690369136923693369436953696369736983699370037013702370337043705370637073708370937103711371237133714371537163717371837193720372137223723372437253726372737283729373037313732373337343735373637373738373937403741374237433744374537463747374837493750375137523753375437553756375737583759376037613762376337643765376637673768376937703771377237733774377537763777377837793780378137823783378437853786378737883789379037913792379337943795379637973798379938003801380238033804380538063807380838093810381138123813381438153816381738183819382038213822382338243825382638273828382938303831383238333834383538363837383838393840384138423843384438453846384738483849385038513852385338543855385638573858385938603861386238633864386538663867386838693870387138723873387438753876387738783879388038813882388338843885388638873888388938903891389238933894389538963897389838993900390139023903390439053906390739083909391039113912391339143915391639173918391939203921392239233924392539263927392839293930393139323933393439353936393739383939394039413942394339443945394639473948394939503951395239533954395539563957395839593960396139623963396439653966396739683969397039713972397339743975397639773978397939803981398239833984398539863987398839893990399139923993399439953996399739983999400040014002400340044005400640074008400940104011401240134014401540164017401840194020402140224023402440254026402740284029403040314032403340344035403640374038403940404041404240434044404540464047404840494050405140524053405440554056405740584059406040614062406340644065406640674068406940704071407240734074407540764077407840794080408140824083408440854086408740884089409040914092409340944095409640974098409941004101410241034104410541064107410841094110411141124113411441154116411741184119412041214122412341244125412641274128412941304131413241334134413541364137413841394140414141424143414441454146414741484149415041514152415341544155415641574158415941604161416241634164416541664167416841694170417141724173417441754176417741784179418041814182418341844185418641874188418941904191419241934194419541964197419841994200420142024203420442054206420742084209421042114212421342144215421642174218421942204221422242234224422542264227422842294230423142324233423442354236423742384239424042414242424342444245424642474248424942504251425242534254425542564257425842594260426142624263426442654266426742684269427042714272427342744275427642774278427942804281428242834284428542864287428842894290429142924293429442954296429742984299430043014302430343044305430643074308430943104311431243134314431543164317431843194320432143224323432443254326432743284329433043314332433343344335433643374338433943404341434243434344434543464347434843494350435143524353435443554356435743584359436043614362436343644365436643674368436943704371437243734374437543764377437843794380438143824383438443854386438743884389439043914392439343944395439643974398439944004401440244034404440544064407440844094410441144124413441444154416441744184419442044214422442344244425442644274428442944304431443244334434443544364437443844394440444144424443444444454446444744484449445044514452445344544455445644574458445944604461446244634464446544664467446844694470447144724473447444754476447744784479448044814482448344844485448644874488448944904491449244934494449544964497449844994500450145024503450445054506450745084509451045114512451345144515451645174518451945204521452245234524452545264527452845294530453145324533453445354536453745384539454045414542454345444545454645474548454945504551455245534554455545564557455845594560456145624563456445654566456745684569457045714572457345744575457645774578457945804581458245834584458545864587458845894590459145924593459445954596459745984599460046014602460346044605460646074608460946104611461246134614461546164617461846194620462146224623462446254626462746284629463046314632463346344635463646374638463946404641464246434644464546464647464846494650465146524653465446554656465746584659466046614662466346644665466646674668466946704671467246734674467546764677467846794680468146824683468446854686468746884689469046914692469346944695469646974698469947004701470247034704470547064707470847094710471147124713471447154716471747184719472047214722472347244725472647274728472947304731473247334734473547364737473847394740474147424743474447454746474747484749475047514752475347544755475647574758475947604761476247634764476547664767476847694770477147724773477447754776477747784779478047814782478347844785478647874788478947904791479247934794479547964797479847994800480148024803480448054806480748084809481048114812481348144815481648174818481948204821482248234824482548264827482848294830483148324833483448354836483748384839484048414842484348444845484648474848484948504851485248534854485548564857485848594860486148624863486448654866486748684869487048714872487348744875487648774878487948804881488248834884488548864887488848894890489148924893489448954896489748984899490049014902490349044905490649074908490949104911491249134914491549164917491849194920492149224923492449254926492749284929493049314932493349344935493649374938493949404941494249434944494549464947494849494950495149524953495449554956495749584959496049614962496349644965496649674968496949704971497249734974497549764977497849794980498149824983498449854986498749884989499049914992499349944995499649974998499950005001500250035004500550065007500850095010501150125013501450155016501750185019502050215022502350245025502650275028502950305031503250335034503550365037503850395040504150425043504450455046504750485049505050515052505350545055505650575058505950605061506250635064506550665067506850695070507150725073507450755076507750785079508050815082508350845085508650875088508950905091509250935094509550965097509850995100510151025103510451055106510751085109511051115112511351145115511651175118511951205121512251235124512551265127512851295130513151325133513451355136513751385139514051415142514351445145514651475148514951505151515251535154515551565157515851595160516151625163516451655166516751685169517051715172517351745175517651775178517951805181518251835184518551865187518851895190519151925193519451955196519751985199520052015202520352045205520652075208520952105211521252135214521552165217521852195220522152225223522452255226522752285229523052315232523352345235523652375238523952405241524252435244524552465247524852495250525152525253525452555256525752585259526052615262526352645265526652675268526952705271527252735274527552765277527852795280528152825283528452855286528752885289529052915292529352945295529652975298529953005301530253035304530553065307530853095310531153125313531453155316531753185319532053215322532353245325532653275328532953305331533253335334533553365337533853395340534153425343534453455346534753485349535053515352535353545355535653575358535953605361536253635364536553665367536853695370537153725373537453755376537753785379538053815382538353845385538653875388538953905391539253935394539553965397539853995400540154025403540454055406540754085409541054115412541354145415541654175418541954205421542254235424542554265427542854295430543154325433543454355436543754385439544054415442544354445445544654475448544954505451545254535454545554565457545854595460546154625463546454655466546754685469547054715472547354745475547654775478547954805481548254835484548554865487548854895490549154925493549454955496549754985499550055015502550355045505550655075508550955105511551255135514551555165517551855195520552155225523552455255526552755285529553055315532553355345535553655375538553955405541554255435544554555465547554855495550555155525553555455555556555755585559556055615562556355645565556655675568556955705571557255735574557555765577557855795580558155825583558455855586558755885589559055915592559355945595559655975598559956005601560256035604560556065607560856095610561156125613561456155616561756185619562056215622562356245625562656275628562956305631563256335634563556365637563856395640564156425643564456455646564756485649565056515652565356545655565656575658565956605661566256635664566556665667566856695670567156725673567456755676567756785679568056815682568356845685568656875688568956905691569256935694569556965697569856995700570157025703570457055706570757085709571057115712571357145715571657175718571957205721572257235724572557265727572857295730573157325733573457355736573757385739574057415742574357445745574657475748574957505751575257535754575557565757575857595760576157625763576457655766576757685769577057715772577357745775577657775778577957805781578257835784578557865787578857895790579157925793579457955796579757985799580058015802580358045805580658075808580958105811581258135814581558165817581858195820582158225823582458255826582758285829583058315832583358345835583658375838583958405841584258435844584558465847584858495850585158525853585458555856585758585859586058615862586358645865586658675868586958705871587258735874587558765877587858795880588158825883588458855886588758885889589058915892589358945895589658975898589959005901590259035904590559065907590859095910591159125913591459155916591759185919592059215922592359245925592659275928592959305931593259335934593559365937593859395940594159425943594459455946594759485949595059515952595359545955595659575958595959605961596259635964596559665967596859695970597159725973597459755976597759785979598059815982598359845985598659875988598959905991599259935994599559965997599859996000600160026003600460056006600760086009601060116012601360146015601660176018601960206021602260236024602560266027602860296030603160326033603460356036603760386039604060416042604360446045604660476048604960506051605260536054605560566057605860596060606160626063606460656066606760686069607060716072607360746075607660776078607960806081608260836084608560866087608860896090609160926093609460956096609760986099610061016102610361046105610661076108610961106111611261136114611561166117611861196120612161226123612461256126612761286129613061316132613361346135613661376138613961406141614261436144614561466147614861496150615161526153615461556156615761586159616061616162616361646165616661676168616961706171617261736174617561766177617861796180618161826183618461856186618761886189619061916192619361946195619661976198619962006201620262036204620562066207620862096210621162126213621462156216621762186219622062216222622362246225622662276228622962306231623262336234623562366237623862396240624162426243624462456246624762486249625062516252625362546255625662576258625962606261626262636264626562666267626862696270627162726273627462756276627762786279628062816282628362846285628662876288628962906291629262936294629562966297629862996300630163026303630463056306630763086309631063116312631363146315631663176318631963206321632263236324632563266327632863296330633163326333633463356336633763386339634063416342634363446345634663476348634963506351635263536354635563566357635863596360636163626363636463656366636763686369637063716372637363746375637663776378637963806381638263836384638563866387638863896390639163926393639463956396639763986399640064016402640364046405640664076408640964106411641264136414641564166417641864196420642164226423642464256426642764286429643064316432643364346435643664376438643964406441644264436444644564466447644864496450645164526453645464556456645764586459646064616462646364646465646664676468646964706471647264736474647564766477647864796480648164826483648464856486648764886489649064916492649364946495649664976498649965006501650265036504650565066507650865096510651165126513651465156516651765186519652065216522652365246525652665276528652965306531653265336534653565366537653865396540654165426543654465456546654765486549655065516552655365546555655665576558655965606561656265636564656565666567656865696570657165726573657465756576657765786579658065816582658365846585658665876588658965906591659265936594659565966597659865996600660166026603660466056606660766086609661066116612661366146615661666176618661966206621662266236624662566266627662866296630663166326633663466356636663766386639664066416642664366446645664666476648664966506651665266536654665566566657665866596660666166626663666466656666666766686669667066716672667366746675667666776678667966806681668266836684668566866687668866896690669166926693669466956696669766986699670067016702670367046705670667076708670967106711671267136714671567166717671867196720672167226723672467256726672767286729673067316732673367346735673667376738673967406741674267436744674567466747674867496750675167526753675467556756675767586759676067616762676367646765676667676768676967706771677267736774677567766777677867796780678167826783678467856786678767886789679067916792679367946795679667976798679968006801680268036804680568066807680868096810681168126813681468156816681768186819682068216822682368246825682668276828682968306831683268336834683568366837683868396840684168426843684468456846684768486849685068516852685368546855685668576858685968606861686268636864686568666867686868696870687168726873687468756876687768786879688068816882688368846885688668876888688968906891689268936894689568966897689868996900690169026903690469056906690769086909691069116912691369146915691669176918691969206921692269236924692569266927692869296930693169326933693469356936693769386939694069416942694369446945694669476948694969506951695269536954695569566957695869596960696169626963696469656966696769686969697069716972697369746975697669776978697969806981698269836984698569866987698869896990699169926993699469956996699769986999700070017002700370047005700670077008700970107011701270137014701570167017701870197020702170227023702470257026702770287029703070317032703370347035703670377038703970407041704270437044704570467047704870497050705170527053705470557056705770587059706070617062706370647065706670677068706970707071707270737074707570767077707870797080708170827083708470857086708770887089709070917092709370947095709670977098709971007101710271037104710571067107710871097110711171127113711471157116711771187119712071217122712371247125712671277128712971307131713271337134713571367137713871397140714171427143714471457146714771487149715071517152715371547155715671577158715971607161716271637164716571667167716871697170717171727173717471757176717771787179718071817182718371847185718671877188718971907191719271937194719571967197719871997200720172027203720472057206720772087209721072117212721372147215721672177218721972207221722272237224722572267227722872297230723172327233723472357236723772387239724072417242724372447245724672477248724972507251725272537254725572567257725872597260726172627263726472657266726772687269727072717272727372747275727672777278727972807281728272837284728572867287728872897290729172927293729472957296729772987299730073017302730373047305730673077308730973107311731273137314731573167317731873197320732173227323732473257326732773287329733073317332733373347335733673377338733973407341734273437344734573467347734873497350735173527353735473557356735773587359736073617362736373647365736673677368736973707371737273737374737573767377737873797380738173827383738473857386738773887389739073917392739373947395739673977398739974007401740274037404740574067407740874097410741174127413741474157416741774187419742074217422742374247425742674277428742974307431743274337434743574367437743874397440744174427443744474457446744774487449745074517452745374547455745674577458745974607461746274637464746574667467746874697470747174727473747474757476747774787479748074817482748374847485748674877488748974907491749274937494749574967497749874997500750175027503750475057506750775087509751075117512751375147515751675177518751975207521752275237524752575267527752875297530753175327533753475357536753775387539754075417542754375447545754675477548754975507551755275537554755575567557755875597560756175627563756475657566756775687569757075717572757375747575757675777578757975807581758275837584758575867587758875897590759175927593759475957596759775987599760076017602760376047605760676077608760976107611761276137614761576167617761876197620762176227623762476257626762776287629763076317632763376347635763676377638763976407641764276437644764576467647764876497650765176527653765476557656765776587659766076617662766376647665766676677668766976707671767276737674767576767677767876797680768176827683768476857686768776887689769076917692769376947695769676977698769977007701770277037704770577067707770877097710771177127713771477157716771777187719772077217722772377247725772677277728772977307731773277337734773577367737773877397740774177427743774477457746774777487749775077517752775377547755775677577758775977607761776277637764776577667767776877697770777177727773777477757776777777787779778077817782778377847785778677877788778977907791779277937794779577967797779877997800780178027803780478057806780778087809781078117812781378147815781678177818781978207821782278237824782578267827782878297830783178327833783478357836783778387839784078417842784378447845784678477848784978507851785278537854785578567857785878597860786178627863786478657866786778687869787078717872787378747875787678777878787978807881788278837884788578867887788878897890789178927893789478957896789778987899790079017902790379047905790679077908790979107911791279137914791579167917791879197920792179227923792479257926792779287929793079317932793379347935793679377938793979407941794279437944794579467947794879497950795179527953795479557956795779587959796079617962796379647965796679677968796979707971797279737974797579767977797879797980798179827983798479857986798779887989799079917992799379947995799679977998799980008001800280038004800580068007800880098010801180128013801480158016801780188019802080218022802380248025802680278028802980308031803280338034803580368037803880398040804180428043804480458046804780488049805080518052805380548055805680578058805980608061806280638064806580668067806880698070807180728073807480758076807780788079808080818082808380848085808680878088808980908091809280938094809580968097809880998100810181028103810481058106810781088109811081118112811381148115811681178118811981208121812281238124812581268127812881298130813181328133813481358136813781388139814081418142814381448145814681478148814981508151815281538154815581568157815881598160816181628163816481658166816781688169817081718172817381748175817681778178817981808181818281838184818581868187818881898190819181928193819481958196819781988199820082018202820382048205820682078208820982108211821282138214821582168217821882198220822182228223822482258226822782288229823082318232823382348235823682378238823982408241824282438244824582468247824882498250825182528253825482558256825782588259826082618262826382648265826682678268826982708271827282738274827582768277827882798280828182828283828482858286828782888289829082918292829382948295829682978298829983008301830283038304830583068307830883098310831183128313831483158316831783188319832083218322832383248325832683278328832983308331833283338334833583368337833883398340834183428343834483458346834783488349835083518352835383548355835683578358835983608361836283638364836583668367836883698370837183728373837483758376837783788379838083818382838383848385838683878388838983908391839283938394839583968397839883998400840184028403840484058406840784088409841084118412841384148415841684178418841984208421842284238424842584268427842884298430843184328433843484358436843784388439844084418442844384448445844684478448844984508451845284538454845584568457845884598460846184628463846484658466846784688469847084718472847384748475847684778478847984808481848284838484848584868487
  1. {
  2. This file is part of the Free Component Library
  3. Copyright (c) 2010-2014 by the Free Pascal development team
  4. SQL source syntax parser test suite
  5. See the file COPYING.FPC, included in this distribution,
  6. for details about the copyright.
  7. This program is distributed in the hope that it will be useful,
  8. but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
  10. **********************************************************************}
  11. unit tcparser;
  12. {$mode objfpc}{$H+}
  13. interface
  14. uses
  15. Classes, SysUtils, fpcunit, fpsqltree, fpsqlscanner, fpsqlparser, testregistry;
  16. type
  17. { TTestParser }
  18. TTestParser = Class(TSQLParser)
  19. public
  20. Procedure ParseStringDef(Out DT : TSQLDataType; Out Len : Integer; Out ACharset : TSQLStringtype);
  21. Function ParseType(Flags : TParseTypeFlags) : TSQLTypeDefinition;
  22. Function ParseConstraint : TSQLExpression;
  23. Function ParseProcedureStatements : TSQLStatement;
  24. end;
  25. { TTestSQLParser }
  26. TTestSQLParser = class(TTestCase)
  27. Private
  28. FParserOptions: TParserOptions;
  29. FSource : TStringStream;
  30. FParser : TTestParser;
  31. FToFree : TSQLElement; //will be freed by test teardown
  32. FErrSource : string;
  33. function GetParserOptions: TParserOptions;
  34. protected
  35. procedure AssertTypeDefaults(TD: TSQLTypeDefinition; Len: Integer=0);
  36. procedure TestStringDef(ASource: String; ExpectDT: TSQLDataType; ExpectLen: Integer; ExpectCharset : TSQLStringType='');
  37. function TestType(ASource : string; AFlags : TParseTypeFlags; AExpectedType : TSQLDataType) : TSQLTypeDefinition;
  38. function TestCheck(ASource : string; AExpectedConstraint : TSQLElementClass) : TSQLExpression;
  39. procedure CreateParser(Const ASource : string; aOptions : TParserOptions = []);
  40. function CheckClass(E : TSQLElement; C : TSQLElementClass) : TSQLElement;
  41. procedure TestDropStatement(Const ASource : string;C : TSQLElementClass);
  42. function TestCreateStatement(Const ASource,AName : string;C: TSQLElementClass) : TSQLCreateOrAlterStatement;
  43. procedure AssertEquals(const AMessage: String; Expected, Actual: TSQLToken); overload;
  44. procedure AssertEquals(const AMessage: String; Expected, Actual: TSQLBinaryoperation); overload;
  45. procedure AssertEquals(const AMessage: String; Expected, Actual: TSQLUnaryoperation); overload;
  46. procedure AssertEquals(const AMessage: String; Expected, Actual: TSQLternaryoperation); overload;
  47. procedure AssertEquals(const AMessage: String; Expected, Actual: TSQLDataType); overload;
  48. procedure AssertEquals(const AMessage: String; Expected, Actual: TForeignKeyAction); overload;
  49. procedure AssertEquals(const AMessage: String; Expected, Actual: TSQLJoinType); overload;
  50. procedure AssertEquals(const AMessage: String; Expected, Actual: TSQLAggregateFunction); overload;
  51. procedure AssertEquals(const AMessage: String; Expected, Actual: TSQLAggregateOption); overload;
  52. procedure AssertEquals(const AMessage: String; Expected, Actual: TSQLOrderDirection); overload;
  53. procedure AssertEquals(const AMessage: String; Expected, Actual: TPlanJoinType); overload;
  54. procedure AssertEquals(const AMessage: String; Expected, Actual: TTriggerMoment); overload;
  55. procedure AssertEquals(const AMessage: String; Expected, Actual: TTriggerState); overload;
  56. procedure AssertEquals(const AMessage: String; Expected, Actual: TTriggerOperations); overload;
  57. function AssertLiteralExpr(Const AMessage : String; Element : TSQLExpression; ALiteralClass : TSQLElementClass) : TSQLLiteral;
  58. procedure AssertIdentifierName(Const AMessage : String; Const AExpected : String; Element : TSQLElement);
  59. procedure AssertField(AField : TSQLElement; Const AName : String; Const AAlias : String = '');
  60. procedure AssertAggregate(AField : TSQLElement; AAgregate : TSQLAggregateFunction; Const AFieldName : String; AOption : TSQLAggregateOption; Const AAlias : String = '');
  61. procedure AssertAggregateExpression(E : TSQLElement; AAgregate : TSQLAggregateFunction; Const AFieldName : String; AOption : TSQLAggregateOption);
  62. procedure AssertTable(ATable : TSQLElement; Const AName : String; Const AAlias : String = '');
  63. function AssertJoin(AJoin : TSQLElement; Const AFirst,ASecond : String; Const aJoinType : TSQLJoinType) : TSQLJoinTableReference;
  64. function AssertJoinOn(AJoin : TSQLExpression; Const AFirst,ASecond : String; Const AOperation : TSQLBinaryOperation) : TSQLBinaryExpression;
  65. function AssertOrderBy(AOrderBy : TSQLElement; Const AField : String; Const ANumber : Integer; Const AOrdering : TSQLOrderDirection) : TSQLOrderByElement;
  66. function AssertSecondaryFile(ASecondaryFile : TSQLElement; Const AFile : String; Const ALength,AStart : Integer) : TSQLDatabaseFileInfo;
  67. procedure TestTypeError;
  68. procedure TestStringError;
  69. procedure TestCheckError;
  70. procedure TestParseError;
  71. procedure SetUp; override;
  72. procedure TearDown; override;
  73. property Parser : TTestParser Read FParser;
  74. property ParserOptions : TParserOptions Read GetParserOptions Write FParserOptions;
  75. property ToFree : TSQLElement Read FToFree Write FTofree;
  76. end;
  77. { TTestDropParser }
  78. TTestDropParser = Class(TTestSQLParser)
  79. published
  80. procedure TestDropDatabase;
  81. procedure TestDropDomain;
  82. procedure TestDropException;
  83. procedure TestDropGenerator;
  84. procedure TestDropIndex;
  85. procedure TestDropProcedure;
  86. procedure TestDropRole;
  87. procedure TestDropTable;
  88. procedure TestDropTrigger;
  89. procedure TestDropView;
  90. procedure TestDropShadow;
  91. procedure TestDropExternalFunction;
  92. end;
  93. { TTestGeneratorParser }
  94. TTestGeneratorParser = Class(TTestSQLParser)
  95. Published
  96. procedure TestCreateGenerator;
  97. procedure TestCreateSequence;
  98. procedure TestAlterSequence;
  99. procedure TestSetGenerator;
  100. end;
  101. { TTestSetTermParser }
  102. TTestSetTermParser = Class(TTestSQLParser)
  103. Published
  104. procedure TestSetTermNoOption;
  105. procedure TestSetTermOption;
  106. end;
  107. { TTestRoleParser }
  108. TTestRoleParser = Class(TTestSQLParser)
  109. Published
  110. procedure TestCreateRole;
  111. procedure TestAlterRole;
  112. end;
  113. { TTestTypeParser }
  114. TTestTypeParser = Class(TTestSQLParser)
  115. private
  116. Published
  117. procedure TestStringType1;
  118. procedure TestStringType2;
  119. procedure TestStringType3;
  120. procedure TestStringType4;
  121. procedure TestStringType5;
  122. procedure TestStringType6;
  123. procedure TestStringType7;
  124. procedure TestStringType8;
  125. procedure TestStringType9;
  126. procedure TestStringType10;
  127. procedure TestStringType11;
  128. procedure TestStringType12;
  129. procedure TestStringType13;
  130. procedure TestStringType14;
  131. procedure TestStringType15;
  132. procedure TestStringType16;
  133. procedure TestStringType17;
  134. procedure TestStringType18;
  135. procedure TestStringType19;
  136. procedure TestStringTypeErrors1;
  137. procedure TestStringTypeErrors2;
  138. procedure TestStringTypeErrors3;
  139. procedure TestTypeInt1;
  140. procedure TestTypeInt2;
  141. procedure TestTypeInt3;
  142. procedure TestTypeInt4;
  143. procedure TestTypeInt5;
  144. procedure TestNumerical1;
  145. procedure TestNumerical2;
  146. procedure TestNumerical3;
  147. procedure TestNumericalError1;
  148. procedure TestNumericalError2;
  149. procedure TestNumericalError3;
  150. procedure TestNumericalError4;
  151. procedure TestNumericalError5;
  152. procedure TestNumericalError6;
  153. procedure TestNumericalError7;
  154. procedure TestBlob1;
  155. procedure TestBlob2;
  156. procedure TestBlob3;
  157. procedure TestBlob4;
  158. procedure TestBlob5;
  159. procedure TestBlob6;
  160. procedure TestBlob7;
  161. procedure TestBlob8;
  162. procedure TestBlobError1;
  163. procedure TestBlobError2;
  164. procedure TestBlobError3;
  165. procedure TestBlobError4;
  166. procedure TestBlobError5;
  167. procedure TestBlobError6;
  168. procedure TestBlobError7;
  169. procedure TestSmallInt;
  170. procedure TestFloat;
  171. procedure TestDoublePrecision;
  172. procedure TestDoublePrecisionDefault;
  173. end;
  174. { TTestCheckParser }
  175. TTestCheckParser = Class (TTestSQLParser)
  176. private
  177. published
  178. procedure TestCheckNull;
  179. procedure TestCheckNotNull;
  180. procedure TestCheckBraces;
  181. procedure TestCheckBracesError;
  182. procedure TestCheckParamError;
  183. procedure TestCheckIdentifierError;
  184. procedure TestIsEqual;
  185. procedure TestIsNotEqual1;
  186. procedure TestIsNotEqual2;
  187. procedure TestGreaterThan;
  188. procedure TestGreaterThanEqual1;
  189. procedure TestGreaterThanEqual2;
  190. procedure TestLessThan;
  191. procedure TestLessThanEqual1;
  192. procedure TestLessThanEqual2;
  193. procedure TestLike;
  194. procedure TestNotLike;
  195. procedure TestContaining;
  196. procedure TestNotContaining;
  197. procedure TestStarting;
  198. procedure TestNotStarting;
  199. procedure TestStartingWith;
  200. procedure TestNotStartingWith;
  201. procedure TestBetween;
  202. procedure TestNotBetween;
  203. procedure TestLikeEscape;
  204. procedure TestNotLikeEscape;
  205. procedure TestAnd;
  206. procedure TestOr;
  207. procedure TestNotOr;
  208. procedure TestCase;
  209. procedure TestAdd;
  210. procedure TestSubtract;
  211. procedure TestMultiply;
  212. procedure TestDivide;
  213. end;
  214. { TTestDomainParser }
  215. // Most relevant tests are in type definition testing.
  216. TTestDomainParser = Class(TTestSQLParser)
  217. private
  218. Published
  219. procedure TestSimpleDomain;
  220. procedure TestSimpleDomainAs;
  221. procedure TestNotNullDomain;
  222. procedure TestDefaultNotNullDomain;
  223. procedure TestCheckDomain;
  224. procedure TestDefaultCheckNotNullDomain;
  225. procedure TestAlterDomainDropDefault;
  226. procedure TestAlterDomainDropCheck;
  227. procedure TestAlterDomainDropCheckError;
  228. procedure TestAlterDomainAddCheck;
  229. procedure TestAlterDomainAddConstraintCheck;
  230. procedure TestAlterDomainAddConstraintError;
  231. procedure TestAlterDomainSetDefault;
  232. procedure TestAlterDomainRename;
  233. procedure TestAlterDomainNewType;
  234. procedure TestAlterDomainNewTypeError1;
  235. procedure TestAlterDomainNewTypeError2;
  236. end;
  237. { TTestExceptionParser }
  238. TTestExceptionParser = Class(TTestSQLParser)
  239. Published
  240. procedure TestException;
  241. procedure TestAlterException;
  242. procedure TestExceptionError1;
  243. procedure TestExceptionError2;
  244. end;
  245. { TTestIndexParser }
  246. TTestIndexParser = Class(TTestSQLParser)
  247. private
  248. Published
  249. procedure TestAlterindexActive;
  250. procedure TestAlterindexInactive;
  251. procedure TestCreateIndexSimple;
  252. procedure TestIndexIndexDouble;
  253. procedure TestCreateIndexAscending;
  254. procedure TestCreateIndexDescending;
  255. procedure TestCreateIndexUnique;
  256. procedure TestCreateIndexUniqueAscending;
  257. procedure TestCreateIndexUniqueDescending;
  258. procedure TestIndexError1;
  259. procedure TestIndexError2;
  260. procedure TestIndexError3;
  261. procedure TestIndexError4;
  262. procedure TestIndexError5;
  263. procedure TestIndexError6;
  264. end;
  265. { TTestTableParser }
  266. TTestTableParser = Class(TTestSQLParser)
  267. private
  268. procedure DoTestCreateReferencesField(Const ASource : String; AOnUpdate,AOnDelete : TForeignKeyAction);
  269. Published
  270. procedure TestCreateOneSimpleField;
  271. procedure TestCreateTwoSimpleFields;
  272. procedure TestCreateOnePrimaryField;
  273. procedure TestCreateOneNamedPrimaryField;
  274. procedure TestCreateOneUniqueField;
  275. procedure TestCreateOneNamedUniqueField;
  276. procedure TestCreateNotNullPrimaryField;
  277. procedure TestCreateNotNullDefaultPrimaryField;
  278. procedure TestCreateComputedByField;
  279. procedure TestCreateCheckField;
  280. procedure TestCreateNamedCheckField;
  281. procedure TestCreateReferencesField;
  282. procedure TestCreateReferencesOnUpdateCascadeField;
  283. procedure TestCreateReferencesOnUpdateNoActionField;
  284. procedure TestCreateReferencesOnUpdateSetDefaultField;
  285. procedure TestCreateReferencesOnUpdateSetNullField;
  286. procedure TestCreateReferencesOnDeleteCascadeField;
  287. procedure TestCreateReferencesOnDeleteNoActionField;
  288. procedure TestCreateReferencesOnDeleteSetDefaultField;
  289. procedure TestCreateReferencesOnDeleteSetNullField;
  290. procedure TestCreateReferencesOnUpdateAndDeleteSetNullField;
  291. procedure TestCreateNamedReferencesField;
  292. procedure TestCreatePrimaryKeyConstraint;
  293. procedure TestCreateNamedPrimaryKeyConstraint;
  294. procedure TestCreateForeignKeyConstraint;
  295. procedure TestCreateNamedForeignKeyConstraint;
  296. procedure TestCreateUniqueConstraint;
  297. procedure TestCreateNamedUniqueConstraint;
  298. procedure TestCreateCheckConstraint;
  299. procedure TestCreateNamedCheckConstraint;
  300. procedure TestAlterDropField;
  301. procedure TestAlterDropFields;
  302. procedure TestAlterDropConstraint;
  303. procedure TestAlterDropConstraints;
  304. procedure TestAlterRenameField;
  305. procedure TestAlterRenameColumnField;
  306. procedure TestAlterFieldType;
  307. procedure TestAlterFieldPosition;
  308. procedure TestAlterAddField;
  309. procedure TestAlterAddFields;
  310. procedure TestAlterAddPrimarykey;
  311. procedure TestAlterAddNamedPrimarykey;
  312. procedure TestAlterAddCheckConstraint;
  313. procedure TestAlterAddNamedCheckConstraint;
  314. procedure TestAlterAddForeignkey;
  315. procedure TestAlterAddNamedForeignkey;
  316. end;
  317. { TTestDeleteParser }
  318. TTestDeleteParser = Class(TTestSQLParser)
  319. Private
  320. function TestDelete(Const ASource , ATable: String) : TSQLDeleteStatement;
  321. Published
  322. procedure TestSimpleDelete;
  323. procedure TestSimpleDeleteAlias;
  324. procedure TestDeleteWhereNull;
  325. end;
  326. { TTestUpdateParser }
  327. TTestUpdateParser = Class(TTestSQLParser)
  328. Private
  329. function TestUpdate(Const ASource , ATable: String) : TSQLUpdateStatement;
  330. Published
  331. procedure TestUpdateOneField;
  332. procedure TestUpdateOneFieldFull;
  333. procedure TestUpdateTwoFields;
  334. procedure TestUpdateOneFieldWhereIsNull;
  335. end;
  336. { TTestInsertParser }
  337. TTestInsertParser = Class(TTestSQLParser)
  338. Private
  339. function TestInsert(Const ASource , ATable: String) : TSQLInsertStatement;
  340. Published
  341. procedure TestInsertOneField;
  342. procedure TestInsertTwoFields;
  343. procedure TestInsertOneValue;
  344. procedure TestInsertTwoValues;
  345. end;
  346. { TTestSelectParser }
  347. TTestSelectParser = Class(TTestSQLParser)
  348. Private
  349. FSelect : TSQLSelectStatement;
  350. function TestSelect(Const ASource : String) : TSQLSelectStatement;
  351. procedure TestSelectError(Const ASource : String);
  352. procedure DoExtractSimple(Expected : TSQLExtractElement);
  353. property Select : TSQLSelectStatement Read FSelect;
  354. Published
  355. procedure TestSelectOneFieldOneTable;
  356. procedure TestSelectOneFieldOneTableTransaction;
  357. procedure TestSelectOneArrayFieldOneTable;
  358. procedure TestSelectTwoFieldsOneTable;
  359. procedure TestSelectOneFieldAliasOneTable;
  360. procedure TestSelectTwoFieldAliasesOneTable;
  361. procedure TestSelectOneTableFieldOneTable;
  362. procedure TestSelectOneDistinctFieldOneTable;
  363. procedure TestSelectOneAllFieldOneTable;
  364. procedure TestSelectAsteriskOneTable;
  365. procedure TestSelectDistinctAsteriskOneTable;
  366. procedure TestSelectAsteriskWithPath;
  367. procedure TestSelectOneFieldOneTableAlias;
  368. procedure TestSelectOneFieldOneTableAsAlias;
  369. procedure TestSelectTwoFieldsTwoTables;
  370. procedure TestSelectTwoFieldsTwoTablesJoin;
  371. procedure TestSelectTwoFieldsTwoInnerTablesJoin;
  372. procedure TestSelectTwoFieldsTwoLeftTablesJoin;
  373. procedure TestSelectTwoFieldsTwoFullOuterTablesJoin;
  374. procedure TestSelectTwoFieldsTwoFullTablesJoin;
  375. procedure TestSelectTwoFieldsTwoRightTablesJoin;
  376. procedure TestSelectTwoFieldsThreeTablesJoin;
  377. procedure TestSelectTwoFieldsBracketThreeTablesJoin;
  378. procedure TestSelectTwoFieldsThreeBracketTablesJoin;
  379. procedure TestSelectTableWithSchema;
  380. procedure TestSelectFieldWithSchema;
  381. procedure TestSelectFirst;
  382. procedure TestSelectFirstSkip;
  383. procedure TestSelectTop;
  384. procedure TestSelectLimit;
  385. procedure TestSelectLimitAll;
  386. procedure TestSelectLimitAllOffset;
  387. procedure TestSelectLimitOffset1;
  388. procedure TestSelectLimitOffset2;
  389. procedure TestSelectOffset;
  390. procedure TestAggregateCount;
  391. procedure TestAggregateCountAsterisk;
  392. procedure TestAggregateCountAll;
  393. procedure TestAggregateCountDistinct;
  394. procedure TestAggregateMax;
  395. procedure TestAggregateMaxAll;
  396. procedure TestAggregateMaxAsterisk;
  397. procedure TestAggregateMaxDistinct;
  398. procedure TestAggregateMin;
  399. procedure TestAggregateMinAll;
  400. procedure TestAggregateMinAsterisk;
  401. procedure TestAggregateMinDistinct;
  402. procedure TestAggregateSum;
  403. procedure TestAggregateSumAll;
  404. procedure TestAggregateSumAsterisk;
  405. procedure TestAggregateSumDistinct;
  406. procedure TestAggregateAvg;
  407. procedure TestAggregateAvgAll;
  408. procedure TestAggregateAvgAsterisk;
  409. procedure TestAggregateAvgDistinct;
  410. procedure TestUpperConst;
  411. procedure TestUpperError;
  412. procedure TestGenID;
  413. procedure TestGenIDError1;
  414. procedure TestGenIDError2;
  415. procedure TestCastSimple;
  416. procedure TestExtractSimple;
  417. procedure TestOrderByOneField;
  418. procedure TestOrderByTwoFields;
  419. procedure TestOrderByThreeFields;
  420. procedure TestOrderByOneDescField;
  421. procedure TestOrderByTwoDescFields;
  422. procedure TestOrderByThreeDescFields;
  423. procedure TestOrderByOneTableField;
  424. procedure TestOrderByOneColumn;
  425. procedure TestOrderByTwoColumns;
  426. procedure TestOrderByTwoColumnsDesc;
  427. procedure TestOrderByCollate;
  428. procedure TestOrderByCollateDesc;
  429. procedure TestOrderByCollateDescTwoFields;
  430. procedure TestGroupByOne;
  431. procedure TestGroupByTwo;
  432. procedure TestHavingOne;
  433. procedure TestUnionSimple;
  434. procedure TestUnionSimpleAll;
  435. procedure TestUnionSimpleOrderBy;
  436. procedure TestUnionDouble;
  437. procedure TestUnionError1;
  438. procedure TestUnionError2;
  439. procedure TestPlanOrderNatural;
  440. procedure TestPlanOrderOrder;
  441. procedure TestPlanOrderIndex1;
  442. procedure TestPlanOrderIndex2;
  443. procedure TestPlanJoinNatural;
  444. procedure TestPlanDefaultNatural;
  445. procedure TestPlanMergeNatural;
  446. procedure TestPlanMergeNested;
  447. procedure TestSubSelect;
  448. procedure TestWhereExists;
  449. procedure TestWhereSingular;
  450. procedure TestWhereAll;
  451. procedure TestWhereAny;
  452. procedure TestWhereSome;
  453. procedure TestParam;
  454. procedure TestParamExpr;
  455. procedure TestNoTable;
  456. procedure TestSourcePosition;
  457. end;
  458. { TTestRollBackParser }
  459. TTestRollBackParser = Class(TTestSQLParser)
  460. Private
  461. FRollback : TSQLRollbackStatement;
  462. function TestRollback(Const ASource : String) : TSQLRollbackStatement;
  463. procedure TestRollbackError(Const ASource : String);
  464. property Rollback : TSQLRollbackStatement Read FRollback;
  465. Published
  466. procedure TestRollback;
  467. procedure TestRollbackWork;
  468. procedure TestRollbackRelease;
  469. procedure TestRollbackWorkRelease;
  470. procedure TestRollbackTransaction;
  471. procedure TestRollbackTransactionWork;
  472. procedure TestRollbackTransactionRelease;
  473. procedure TestRollbackTransactionWorkRelease;
  474. end;
  475. { TTestCommitParser }
  476. TTestCommitParser = Class(TTestSQLParser)
  477. Private
  478. FCommit : TSQLCommitStatement;
  479. function TestCommit(Const ASource : String) : TSQLCommitStatement;
  480. procedure TestCommitError(Const ASource : String);
  481. property Commit : TSQLCommitStatement Read FCommit;
  482. Published
  483. procedure TestCommit;
  484. procedure TestCommitWork;
  485. procedure TestCommitRelease;
  486. procedure TestCommitWorkRelease;
  487. procedure TestCommitTransaction;
  488. procedure TestCommitTransactionWork;
  489. procedure TestCommitTransactionRelease;
  490. procedure TestCommitTransactionWorkRelease;
  491. procedure TestCommitRetain;
  492. procedure TestCommitWorkRetain;
  493. procedure TestCommitReleaseRetain;
  494. procedure TestCommitWorkReleaseRetain;
  495. procedure TestCommitTransactionRetain;
  496. procedure TestCommitTransactionWorkRetain;
  497. procedure TestCommitTransactionReleaseRetain;
  498. procedure TestCommitTransactionWorkReleaseRetain;
  499. procedure TestCommitRetainSnapShot;
  500. end;
  501. { TTestExecuteProcedureParser }
  502. TTestExecuteProcedureParser = Class(TTestSQLParser)
  503. Private
  504. FExecute : TSQLExecuteProcedureStatement;
  505. function TestExecute(Const ASource : String) : TSQLExecuteProcedureStatement;
  506. procedure TestExecuteError(Const ASource : String);
  507. property Execute: TSQLExecuteProcedureStatement Read FExecute;
  508. Published
  509. procedure TestExecuteSimple;
  510. procedure TestExecuteSimpleTransaction;
  511. procedure TestExecuteSimpleReturningValues;
  512. procedure TestExecuteSimpleReturning2Values;
  513. procedure TestExecuteOneArg;
  514. procedure TestExecuteOneArgNB;
  515. procedure TestExecuteTwoArgs;
  516. procedure TestExecuteTwoArgsNB;
  517. procedure TestExecuteOneArgSelect;
  518. procedure TestExecuteOneArgSelectNB;
  519. procedure TestExecuteTwoArgsSelect;
  520. procedure TestExecuteTwoArgsSelectNB;
  521. procedure TestExecuteOneArgSelectErr;
  522. procedure TestExecuteOneArgSelectErr2;
  523. procedure TestExecuteOneArgSelectErr3;
  524. procedure TestExecuteOneArgSelectErr4;
  525. end;
  526. { TTestConnectParser }
  527. TTestConnectParser = Class(TTestSQLParser)
  528. Private
  529. FConnect : TSQLConnectStatement;
  530. function TestConnect(Const ASource : String) : TSQLConnectStatement;
  531. procedure TestConnectError(Const ASource : String);
  532. property Connect: TSQLConnectStatement Read FConnect;
  533. Published
  534. procedure TestConnectSimple;
  535. procedure TestConnectUser;
  536. procedure TestConnectPassword;
  537. procedure TestConnectUserPassword;
  538. procedure TestConnectUserPasswordRole;
  539. procedure TestConnectUserPasswordRoleCache;
  540. procedure TestConnectSimpleCache;
  541. end;
  542. { TTestCreateDatabaseParser }
  543. TTestCreateDatabaseParser = Class(TTestSQLParser)
  544. Private
  545. FCreateDB : TSQLCreateDatabaseStatement;
  546. function TestCreate(Const ASource : String) : TSQLCreateDatabaseStatement;
  547. procedure TestCreateError(Const ASource : String);
  548. property CreateDB : TSQLCreateDatabaseStatement Read FCreateDB;
  549. published
  550. procedure TestSimple;
  551. procedure TestSimpleSchema;
  552. procedure TestSimpleUSer;
  553. procedure TestSimpleUSerPassword;
  554. procedure TestSimplePassword;
  555. procedure TestPageSize;
  556. procedure TestPageSize2;
  557. procedure TestPageSizeLength;
  558. procedure TestPageSizeLength2;
  559. procedure TestPageSizeLength3;
  560. procedure TestPageSizeLength4;
  561. procedure TestCharset;
  562. procedure TestSecondaryFile1;
  563. procedure TestSecondaryFile2;
  564. procedure TestSecondaryFile3;
  565. procedure TestSecondaryFile4;
  566. procedure TestSecondaryFile5;
  567. procedure TestSecondaryFile6;
  568. procedure TestSecondaryFile7;
  569. procedure TestSecondaryFile8;
  570. procedure TestSecondaryFile9;
  571. procedure TestSecondaryFile10;
  572. procedure TestSecondaryFileS;
  573. procedure TestSecondaryFileError1;
  574. procedure TestSecondaryFileError2;
  575. procedure TestSecondaryFileError3;
  576. end;
  577. { TTestAlterDatabaseParser }
  578. TTestAlterDatabaseParser = Class(TTestSQLParser)
  579. Private
  580. FAlterDB : TSQLAlterDatabaseStatement;
  581. function TestAlter(Const ASource : String) : TSQLAlterDatabaseStatement;
  582. procedure TestAlterError(Const ASource : String);
  583. property AlterDB : TSQLAlterDatabaseStatement Read FAlterDB;
  584. published
  585. procedure TestSimple;
  586. procedure TestLength;
  587. procedure TestStarting;
  588. procedure TestStartingLength;
  589. procedure TestFiles;
  590. procedure TestFiles2;
  591. procedure TestError;
  592. procedure TestFilesError;
  593. end;
  594. { TTestCreateViewParser }
  595. TTestCreateViewParser = Class(TTestSQLParser)
  596. Private
  597. FView : TSQLCreateViewStatement;
  598. function TestCreate(Const ASource : String) : TSQLCreateViewStatement;
  599. procedure TestCreateError(Const ASource : String);
  600. property View : TSQLCreateViewStatement Read FView;
  601. Published
  602. procedure TestSimple;
  603. procedure TestFieldList;
  604. procedure TestFieldList2;
  605. procedure TestSimpleWithCheckoption;
  606. end;
  607. { TTestCreateShadowParser }
  608. TTestCreateShadowParser = Class(TTestSQLParser)
  609. Private
  610. FShadow : TSQLCreateShadowStatement;
  611. function TestCreate(Const ASource : String) : TSQLCreateShadowStatement;
  612. procedure TestCreateError(Const ASource : String);
  613. property Shadow : TSQLCreateShadowStatement Read FShadow;
  614. published
  615. procedure TestSimple;
  616. procedure TestLength;
  617. procedure TestLength2;
  618. procedure TestLength3;
  619. procedure TestLength4;
  620. procedure TestSecondaryFile1;
  621. procedure TestSecondaryFile2;
  622. procedure TestSecondaryFile3;
  623. procedure TestSecondaryFile4;
  624. procedure TestSecondaryFile5;
  625. procedure TestSecondaryFile6;
  626. procedure TestSecondaryFile7;
  627. procedure TestSecondaryFile8;
  628. procedure TestSecondaryFileS;
  629. end;
  630. { TTestProcedureStatement }
  631. TTestProcedureStatement = Class(TTestSQLParser)
  632. Private
  633. FStatement : TSQLStatement;
  634. procedure TestParseStatementError;
  635. function TestStatement(Const ASource : String) : TSQLStatement;
  636. procedure TestStatementError(Const ASource : String);
  637. Public
  638. property Statement : TSQLStatement Read FStatement;
  639. Published
  640. procedure TestException;
  641. procedure TestExceptionError;
  642. procedure TestExit;
  643. procedure TestSuspend;
  644. procedure TestEmptyBlock;
  645. procedure TestExitBlock;
  646. procedure TestExitBlockError;
  647. procedure TestPostEvent;
  648. procedure TestPostEventColName;
  649. procedure TestPostError;
  650. procedure TestAssignSimple;
  651. procedure TestAssignSimpleNew;
  652. procedure TestAssignSelect;
  653. procedure TestBlockAssignSimple;
  654. procedure TestIf;
  655. procedure TestIfBlock;
  656. procedure TestIfElse;
  657. procedure TestIfBlockElse;
  658. procedure TestIfElseError;
  659. procedure TestIfBlockElseBlock;
  660. procedure TestIfErrorBracketLeft;
  661. procedure TestIfErrorBracketRight;
  662. procedure TestIfErrorNoThen;
  663. procedure TestIfErrorSemicolonElse;
  664. procedure TestWhile;
  665. procedure TestWhileBlock;
  666. procedure TestWhileErrorBracketLeft;
  667. procedure TestWhileErrorBracketRight;
  668. procedure TestWhileErrorNoDo;
  669. procedure TestWhenAny;
  670. procedure TestWhenSQLCode;
  671. procedure TestWhenGDSCode;
  672. procedure TestWhenException;
  673. procedure TestWhenExceptionGDS;
  674. procedure TestWhenAnyBlock;
  675. procedure TestWhenErrorAny;
  676. procedure TestWhenErrorNoDo;
  677. procedure TestWhenErrorExceptionInt;
  678. procedure TestWhenErrorExceptionString;
  679. procedure TestWhenErrorSqlCode;
  680. procedure TestWhenErrorGDSCode;
  681. procedure TestExecuteStatement;
  682. procedure TestExecuteStatementReturningValues;
  683. procedure TestExecuteStatementReturningValuesColon;
  684. procedure TestExecuteStatementReturningValuesBrackets;
  685. procedure TestForSimple;
  686. procedure TestForSimpleNoColon;
  687. procedure TestForSimple2fields;
  688. procedure TestForBlock;
  689. end;
  690. { TTestCreateProcedureParser }
  691. TTestCreateProcedureParser = Class(TTestSQLParser)
  692. Private
  693. FStatement : TSQLCreateProcedureStatement;
  694. function TestCreate(Const ASource : String) : TSQLCreateProcedureStatement;
  695. procedure TestCreateError(Const ASource : String);
  696. property Statement : TSQLCreateProcedureStatement Read FStatement;
  697. Published
  698. procedure TestEmptyProcedure;
  699. procedure TestExitProcedure;
  700. procedure TestProcedureOneArgument;
  701. procedure TestProcedureTwoArguments;
  702. procedure TestProcedureOneReturnValue;
  703. procedure TestProcedureTwoReturnValues;
  704. procedure TestProcedureOneLocalVariable;
  705. procedure TestProcedureTwoLocalVariable;
  706. procedure TestProcedureInputOutputLocal;
  707. end;
  708. { TTestCreateTriggerParser }
  709. TTestCreateTriggerParser = Class(TTestSQLParser)
  710. Private
  711. FStatement : TSQLAlterCreateTriggerStatement;
  712. function TestCreate(Const ASource : String) : TSQLCreateTriggerStatement;
  713. function TestAlter(Const ASource : String) : TSQLAlterTriggerStatement;
  714. procedure TestCreateError(Const ASource : String);
  715. property Statement : TSQLAlterCreateTriggerStatement Read FStatement;
  716. Published
  717. procedure TestEmptyTrigger;
  718. procedure TestExitTrigger;
  719. procedure TestEmptyTriggerAfterUpdate;
  720. procedure TestEmptyTriggerBeforeDelete;
  721. procedure TestEmptyTriggerBeforeInsert;
  722. procedure TestEmptyTriggerBeforeInsertPosition1;
  723. procedure TestEmptyTriggerBeforeInsertPosition1inActive;
  724. procedure TestEmptyTriggerBeforeInsertPosition1Active;
  725. procedure TestTriggerOneLocalVariable;
  726. procedure TestTriggerTwoLocalVariables;
  727. procedure TestAlterTrigger;
  728. end;
  729. { TTestDeclareExternalFunctionParser }
  730. TTestDeclareExternalFunctionParser = Class(TTestSQLParser)
  731. Private
  732. FStatement : TSQLDeclareExternalFunctionStatement;
  733. function TestCreate(Const ASource : String) : TSQLDeclareExternalFunctionStatement;
  734. procedure TestCreateError(Const ASource : String);
  735. property Statement : TSQLDeclareExternalFunctionStatement Read FStatement;
  736. Published
  737. procedure TestEmptyfunction;
  738. procedure TestEmptyfunctionByValue;
  739. procedure TestCStringfunction;
  740. procedure TestCStringFreeItfunction;
  741. procedure TestOneArgumentFunction;
  742. procedure TestTwoArgumentsFunction;
  743. end;
  744. { TTestGrantParser }
  745. TTestGrantParser = Class(TTestSQLParser)
  746. Private
  747. FStatement : TSQLGrantStatement;
  748. function TestGrant(Const ASource : String) : TSQLGrantStatement;
  749. procedure TestGrantError(Const ASource : String);
  750. property Statement : TSQLGrantStatement Read FStatement;
  751. Published
  752. procedure TestSimple;
  753. procedure Test2Operations;
  754. procedure TestDeletePrivilege;
  755. procedure TestUpdatePrivilege;
  756. procedure TestInsertPrivilege;
  757. procedure TestReferencePrivilege;
  758. procedure TestAllPrivileges;
  759. procedure TestAllPrivileges2;
  760. procedure TestUpdateColPrivilege;
  761. procedure TestUpdate2ColsPrivilege;
  762. procedure TestReferenceColPrivilege;
  763. procedure TestReference2ColsPrivilege;
  764. procedure TestUserPrivilege;
  765. procedure TestUserPrivilegeWithGrant;
  766. procedure TestGroupPrivilege;
  767. procedure TestProcedurePrivilege;
  768. procedure TestViewPrivilege;
  769. procedure TestTriggerPrivilege;
  770. procedure TestPublicPrivilege;
  771. procedure TestExecuteToUser;
  772. procedure TestExecuteToProcedure;
  773. procedure TestRoleToUser;
  774. procedure TestRoleToUserWithAdmin;
  775. procedure TestRoleToPublic;
  776. procedure Test2RolesToUser;
  777. end;
  778. { TTestRevokeParser }
  779. TTestRevokeParser = Class(TTestSQLParser)
  780. Private
  781. FStatement : TSQLRevokeStatement;
  782. function TestRevoke(Const ASource : String) : TSQLRevokeStatement;
  783. procedure TestRevokeError(Const ASource : String);
  784. property Statement : TSQLRevokeStatement Read FStatement;
  785. Published
  786. procedure TestSimple;
  787. procedure Test2Operations;
  788. procedure TestDeletePrivilege;
  789. procedure TestUpdatePrivilege;
  790. procedure TestInsertPrivilege;
  791. procedure TestReferencePrivilege;
  792. procedure TestAllPrivileges;
  793. procedure TestAllPrivileges2;
  794. procedure TestUpdateColPrivilege;
  795. procedure TestUpdate2ColsPrivilege;
  796. procedure TestReferenceColPrivilege;
  797. procedure TestReference2ColsPrivilege;
  798. procedure TestUserPrivilege;
  799. procedure TestUserPrivilegeWithRevoke;
  800. procedure TestGroupPrivilege;
  801. procedure TestProcedurePrivilege;
  802. procedure TestViewPrivilege;
  803. procedure TestTriggerPrivilege;
  804. procedure TestPublicPrivilege;
  805. procedure TestExecuteToUser;
  806. procedure TestExecuteToProcedure;
  807. procedure TestRoleToUser;
  808. procedure TestRoleToPublic;
  809. procedure Test2RolesToUser;
  810. end;
  811. { TTestGlobalParser }
  812. TTestGlobalParser = Class(TTestSQLParser)
  813. published
  814. procedure TestEmpty;
  815. end;
  816. implementation
  817. uses typinfo;
  818. { TTestSetTermParser }
  819. procedure TTestSetTermParser.TestSetTermNoOption;
  820. begin
  821. FErrSource:='SET TERM ^ ;';
  822. AssertException(ESQLParser,@TestParseError);
  823. end;
  824. procedure TTestSetTermParser.TestSetTermOption;
  825. begin
  826. CreateParser('SET TERM ^ ;');
  827. FToFree:=Parser.Parse([poAllowSetTerm]);
  828. AssertEquals('Terminator set','^',Parser.Scanner.AlternateTerminator);
  829. end;
  830. { TTestGlobalParser }
  831. procedure TTestGlobalParser.TestEmpty;
  832. begin
  833. CreateParser('');
  834. AssertNull('Empty statement returns nil',Parser.Parse);
  835. end;
  836. { --------------------------------------------------------------------
  837. TTestParser
  838. --------------------------------------------------------------------}
  839. procedure TTestParser.ParseStringDef(Out DT: TSQLDataType; Out Len: Integer; Out ACharset : TSQLStringtype);
  840. begin
  841. ParseCharTypeDefinition(DT,Len,ACharset);
  842. end;
  843. function TTestParser.ParseType(Flags: TParseTypeFlags): TSQLTypeDefinition;
  844. begin
  845. Result:=ParseTypeDefinition(Nil,Flags);
  846. end;
  847. function TTestParser.ParseConstraint: TSQLExpression;
  848. begin
  849. // GetNextToken;
  850. Result:=ParseCheckConstraint(Nil);
  851. end;
  852. function TTestParser.ParseProcedureStatements: TSQLStatement;
  853. begin
  854. Result:=Self.ParseProcedureStatement(Nil);
  855. end;
  856. { --------------------------------------------------------------------
  857. TTestSQLParser
  858. --------------------------------------------------------------------}
  859. procedure TTestSQLParser.SetUp;
  860. begin
  861. // nothing yet
  862. end;
  863. procedure TTestSQLParser.TearDown;
  864. begin
  865. FreeAndNil(FParser);
  866. FreeAndNil(FSource);
  867. FreeAndNil(FToFree);
  868. end;
  869. procedure TTestSQLParser.CreateParser(const ASource: string; aOptions: TParserOptions = []);
  870. begin
  871. FSource:=TStringStream.Create(ASource);
  872. FParserOptions:=aOptions;
  873. FParser:=TTestParser.Create(FSource);
  874. end;
  875. Function TTestSQLParser.CheckClass(E: TSQLElement; C: TSQLElementClass) : TSQLElement;
  876. begin
  877. AssertEquals(C,E.ClassType);
  878. Result:=E;
  879. end;
  880. procedure TTestSQLParser.AssertEquals(const AMessage: String; Expected, Actual: TSQLToken);
  881. Var
  882. NE,NA : String;
  883. begin
  884. NE:=GetEnumName(TypeInfo(TSQLToken),Ord(Expected));
  885. NA:=GetEnumName(TypeInfo(TSQLToken),Ord(Actual));
  886. AssertEquals(AMessage,NE,NA);
  887. end;
  888. procedure TTestSQLParser.AssertEquals(const AMessage: String; Expected,
  889. Actual: TSQLBinaryOperation);
  890. Var
  891. NE,NA : String;
  892. begin
  893. NE:=GetEnumName(TypeInfo(TSQLBinaryOperation),Ord(Expected));
  894. NA:=GetEnumName(TypeInfo(TSQLBinaryOperation),Ord(Actual));
  895. AssertEquals(AMessage,NE,NA);
  896. end;
  897. procedure TTestSQLParser.AssertEquals(const AMessage: String; Expected,
  898. Actual: TSQLUnaryoperation);
  899. Var
  900. NE,NA : String;
  901. begin
  902. NE:=GetEnumName(TypeInfo(TSQLUnaryOperation),Ord(Expected));
  903. NA:=GetEnumName(TypeInfo(TSQLUnaryOperation),Ord(Actual));
  904. AssertEquals(AMessage,NE,NA);
  905. end;
  906. procedure TTestSQLParser.AssertEquals(const AMessage: String; Expected,
  907. Actual: TSQLternaryoperation);
  908. Var
  909. NE,NA : String;
  910. begin
  911. NE:=GetEnumName(TypeInfo(TSQLTernaryOperation),Ord(Expected));
  912. NA:=GetEnumName(TypeInfo(TSQLTernaryOperation),Ord(Actual));
  913. AssertEquals(AMessage,NE,NA);
  914. end;
  915. procedure TTestSQLParser.AssertEquals(const AMessage: String; Expected, Actual: TSQLDataType);
  916. Var
  917. NE,NA : String;
  918. begin
  919. NE:=GetEnumName(TypeInfo(TSQLDataType),Ord(Expected));
  920. NA:=GetEnumName(TypeInfo(TSQLDataType),Ord(Actual));
  921. AssertEquals(AMessage,NE,NA);
  922. end;
  923. procedure TTestSQLParser.AssertEquals(const AMessage: String; Expected,
  924. Actual: TForeignKeyAction);
  925. Var
  926. NE,NA : String;
  927. begin
  928. NE:=GetEnumName(TypeInfo(TForeignKeyAction),Ord(Expected));
  929. NA:=GetEnumName(TypeInfo(TForeignKeyAction),Ord(Actual));
  930. AssertEquals(AMessage,NE,NA);
  931. end;
  932. procedure TTestSQLParser.AssertEquals(const AMessage: String; Expected,
  933. Actual: TSQLJoinType);
  934. Var
  935. NE,NA : String;
  936. begin
  937. NE:=GetEnumName(TypeInfo(TSQLJoinType),Ord(Expected));
  938. NA:=GetEnumName(TypeInfo(TSQLJoinType),Ord(Actual));
  939. AssertEquals(AMessage,NE,NA);
  940. end;
  941. procedure TTestSQLParser.AssertEquals(const AMessage: String; Expected,
  942. Actual: TSQLAggregateFunction);
  943. Var
  944. NE,NA : String;
  945. begin
  946. NE:=GetEnumName(TypeInfo(TSQLAggregateFunction),Ord(Expected));
  947. NA:=GetEnumName(TypeInfo(TSQLAggregateFunction),Ord(Actual));
  948. AssertEquals(AMessage,NE,NA);
  949. end;
  950. procedure TTestSQLParser.AssertEquals(const AMessage: String; Expected,
  951. Actual: TSQLAggregateOption);
  952. Var
  953. NE,NA : String;
  954. begin
  955. NE:=GetEnumName(TypeInfo(TSQLAggregateOption),Ord(Expected));
  956. NA:=GetEnumName(TypeInfo(TSQLAggregateOption),Ord(Actual));
  957. AssertEquals(AMessage,NE,NA);
  958. end;
  959. procedure TTestSQLParser.AssertEquals(const AMessage: String; Expected,
  960. Actual: TSQLOrderDirection);
  961. Var
  962. NE,NA : String;
  963. begin
  964. NE:=GetEnumName(TypeInfo(TSQLOrderDirection),Ord(Expected));
  965. NA:=GetEnumName(TypeInfo(TSQLOrderDirection),Ord(Actual));
  966. AssertEquals(AMessage,NE,NA);
  967. end;
  968. procedure TTestSQLParser.AssertEquals(const AMessage: String; Expected,
  969. Actual: TPlanJoinType);
  970. Var
  971. NE,NA : String;
  972. begin
  973. NE:=GetEnumName(TypeInfo(TPlanJoinType),Ord(Expected));
  974. NA:=GetEnumName(TypeInfo(TPlanJoinType),Ord(Actual));
  975. AssertEquals(AMessage,NE,NA);
  976. end;
  977. procedure TTestSQLParser.AssertEquals(const AMessage: String; Expected,
  978. Actual: TTriggerMoment);
  979. Var
  980. NE,NA : String;
  981. begin
  982. NE:=GetEnumName(TypeInfo(TTriggerMoment),Ord(Expected));
  983. NA:=GetEnumName(TypeInfo(TTriggerMoment),Ord(Actual));
  984. AssertEquals(AMessage,NE,NA);
  985. end;
  986. procedure TTestSQLParser.AssertEquals(const AMessage: String; Expected,
  987. Actual: TTriggerState);
  988. Var
  989. NE,NA : String;
  990. begin
  991. NE:=GetEnumName(TypeInfo(TTriggerState),Ord(Expected));
  992. NA:=GetEnumName(TypeInfo(TTriggerState),Ord(Actual));
  993. AssertEquals(AMessage,NE,NA);
  994. end;
  995. procedure TTestSQLParser.AssertEquals(const AMessage: String; Expected,
  996. Actual: TTriggerOperations);
  997. begin
  998. If Expected<>Actual then
  999. Fail(Amessage)
  1000. end;
  1001. Function TTestSQLParser.AssertLiteralExpr(const AMessage: String;
  1002. Element: TSQLExpression; ALiteralClass: TSQLElementClass) : TSQLLiteral;
  1003. begin
  1004. CheckClass(Element,TSQLLiteralExpression);
  1005. Result:=TSQLLiteral(Checkclass(TSQLLiteralExpression(Element).Literal,ALiteralClass));
  1006. end;
  1007. procedure TTestSQLParser.AssertIdentifierName(const AMessage : String;
  1008. const AExpected: String; Element: TSQLElement);
  1009. begin
  1010. AssertNotNull(AMessage+': Have identifier ',Element);
  1011. CheckClass(Element,TSQLidentifierName);
  1012. AssertEquals(AMessage+': Correct identifier name',AExpected,TSQLidentifierName(Element).Name);
  1013. end;
  1014. procedure TTestSQLParser.AssertField(AField: TSQLElement; const AName: String;
  1015. const AAlias: String);
  1016. Var
  1017. F : TSQLSelectField;
  1018. E : TSQLidentifierExpression;
  1019. begin
  1020. AssertNotNull('Have field',AField);
  1021. F:=TSQLSelectField(CheckClass(AField,TSQLSelectField));
  1022. AssertNotNull('Have field expresssion,',F.Expression);
  1023. E:=TSQLidentifierExpression(CheckClass(F.Expression,TSQLidentifierExpression));
  1024. AssertIdentifierName('Correct field name',AName,E.Identifier);
  1025. If (AAlias<>'') then
  1026. AssertIdentifierName('Correct alias',AALias,F.AliasName);
  1027. end;
  1028. procedure TTestSQLParser.AssertAggregate(AField: TSQLElement;
  1029. AAgregate: TSQLAggregateFunction; const AFieldName: String;
  1030. AOption: TSQLAggregateOption; const AAlias: String);
  1031. Var
  1032. F : TSQLSelectField;
  1033. begin
  1034. AssertNotNull('Have field',AField);
  1035. F:=TSQLSelectField(CheckClass(AField,TSQLSelectField));
  1036. AssertNotNull('Have field expresssion,',F.Expression);
  1037. AssertAggregateExpression(F.Expression,AAgregate,AFieldName,AOption);
  1038. If (AAlias<>'') then
  1039. AssertIdentifierName('Correct alias',AALias,F.AliasName);
  1040. end;
  1041. procedure TTestSQLParser.AssertAggregateExpression(E: TSQLElement;
  1042. AAgregate: TSQLAggregateFunction; const AFieldName: String;
  1043. AOption: TSQLAggregateOption);
  1044. Var
  1045. AF : TSQLAggregateFunctionExpression;
  1046. I : TSQLIdentifierExpression;
  1047. begin
  1048. AF:=TSQLAggregateFunctionExpression(CheckClass(E,TSQLAggregateFunctionExpression));
  1049. AssertEquals('Correct function',AAgregate,AF.Aggregate);
  1050. AssertEquals('Correct function',AOption,AF.Option);
  1051. If (AFieldName<>'') then
  1052. begin
  1053. I:=TSQLIdentifierExpression(CheckClass(AF.Expression, TSQLIdentifierExpression));
  1054. AssertIdentifierName('Correct field name',AFieldName,I.Identifier);
  1055. end;
  1056. end;
  1057. procedure TTestSQLParser.AssertTable(ATable: TSQLElement; const AName: String;
  1058. const AAlias: String);
  1059. Var
  1060. T : TSQLSimpleTablereference;
  1061. begin
  1062. AssertNotNull('Have table',ATable);
  1063. T:=TSQLSimpleTablereference(CheckClass(ATable,TSQLSimpleTablereference));
  1064. AssertIdentifierName('Correct table name',AName,T.ObjectName);
  1065. If (AAlias<>'') then
  1066. AssertIdentifierName('Correct alias',AALias,T.AliasName);
  1067. end;
  1068. function TTestSQLParser.AssertJoin(AJoin: TSQLElement; const AFirst,
  1069. ASecond: String; const ajointype: TSQLJoinType):TSQLJoinTableReference;
  1070. Var
  1071. J : TSQLJoinTableReference;
  1072. begin
  1073. AssertNotNull('Have join',AJoin);
  1074. J:=TSQLJoinTableReference(CheckClass(AJoin,TSQLJoinTableReference));
  1075. if (AFirst<>'') then
  1076. AssertTable(J.Left,AFirst,'');
  1077. if (ASecond<>'') then
  1078. AssertTable(J.Right,ASecond,'');
  1079. AssertEquals('Correct join type',AJoinType,J.JoinType);
  1080. Result:=J;
  1081. end;
  1082. function TTestSQLParser.AssertJoinOn(AJoin: TSQLExpression; const AFirst,
  1083. ASecond: String; const AOperation: TSQLBinaryOperation): TSQLBinaryExpression;
  1084. Var
  1085. I : TSQLIdentifierExpression;
  1086. begin
  1087. Result:=TSQLBinaryExpression(CheckClass(AJoin,TSQLBinaryExpression));
  1088. AssertEquals('Correct ON operation',AOperation,Result.Operation);
  1089. I:=TSQLIdentifierExpression(CheckClass(Result.Left,TSQLIdentifierExpression));
  1090. AssertIdentifierName('Left field name',AFirst,I.Identifier);
  1091. I:=TSQLIdentifierExpression(CheckClass(Result.Right,TSQLIdentifierExpression));
  1092. AssertIdentifierName('Right field name',ASecond,I.Identifier);
  1093. end;
  1094. function TTestSQLParser.AssertOrderBy(AOrderBy: TSQLElement;
  1095. const AField: String; const ANumber: Integer; const AOrdering: TSQLOrderDirection
  1096. ): TSQLOrderByElement;
  1097. Var
  1098. I : TSQLIntegerLiteral;
  1099. begin
  1100. Result:=TSQLOrderByElement(CheckClass(AorderBy,TSQLOrderByElement));
  1101. If (AField<>'') then
  1102. AssertIdentifierName('Correct order by field',AField,Result.Field)
  1103. else if (ANumber>0) then
  1104. begin
  1105. I:=TSQLIntegerLiteral(CheckClass(Result.Field,TSQLIntegerLiteral));
  1106. AssertEquals('Correct order by column number',ANumber,I.Value);
  1107. end;
  1108. AssertEquals('Correct ordering',AOrdering,Result.OrderBy);
  1109. end;
  1110. function TTestSQLParser.AssertSecondaryFile(ASecondaryFile: TSQLElement;
  1111. const AFile: String; const ALength, AStart: Integer): TSQLDatabaseFileInfo;
  1112. begin
  1113. Result:=TSQLDatabaseFileInfo(CheckClass(ASecondaryFile,TSQLDatabaseFileInfo));
  1114. AssertEquals('Secondary file name',AFile,Result.FileName);
  1115. AssertEquals('Secondary file length',ALength,Result.Length);
  1116. AssertEquals('Secondary file start',AStart,Result.StartPage);
  1117. end;
  1118. procedure TTestSQLParser.TestTypeError;
  1119. begin
  1120. TestType(FErrSource,[],sdtInteger);
  1121. end;
  1122. procedure TTestSQLParser.TestStringError;
  1123. begin
  1124. TestStringDef(FErrSource,sdtchar,0);
  1125. end;
  1126. procedure TTestSQLParser.TestCheckError;
  1127. begin
  1128. TestCheck(FErrSource,TSQLExpression);
  1129. end;
  1130. procedure TTestSQLParser.TestParseError;
  1131. begin
  1132. CreateParser(FErrSource);
  1133. FToFree:=Parser.Parse;
  1134. end;
  1135. procedure TTestSQLParser.TestStringDef(ASource : String; ExpectDT : TSQLDataType; ExpectLen : Integer; ExpectCharset : TSQLStringType='');
  1136. Var
  1137. Dt : TSQLDataType;
  1138. L : integer;
  1139. cs : TSQLStringType;
  1140. begin
  1141. CreateParser(ASOURCE);
  1142. Parser.GetNextToken;
  1143. Parser.ParseStringDef(dt,l,cs);
  1144. AssertEquals('Datatype is CHAR',ExpectDT,Dt);
  1145. AssertEquals('Length is 1',ExpectLen,l);
  1146. AssertEquals('End of Stream reached',tsqlEOF,Parser.CurrentToken);
  1147. AssertEquals('Correct character set',ExpectCharset,CS);
  1148. end;
  1149. Function TTestSQLParser.TestType(ASource : string; AFlags : TParseTypeFlags; AExpectedType : TSQLDataType) : TSQLTypeDefinition;
  1150. begin
  1151. CreateParser(ASource);
  1152. FToFree:=Parser.ParseType(AFlags);
  1153. AssertNotNull('ParseType returns result',FToFree);
  1154. CheckClass(FTofree,TSQLTypeDefinition);
  1155. Result:=TSQLTypeDefinition(FToFree);
  1156. AssertEquals('Type definition has correct data type',AExpectedType,Result.Datatype);
  1157. end;
  1158. function TTestSQLParser.TestCheck(ASource: string; AExpectedConstraint: TSQLElementClass
  1159. ): TSQLExpression;
  1160. begin
  1161. CreateParser('('+ASource+')');
  1162. FToFree:=Parser.ParseConstraint();
  1163. AssertNotNull('ParseType returns result',FToFree);
  1164. CheckClass(FTofree,AExpectedConstraint);
  1165. Result:=TSQLExpression(FToFree);
  1166. AssertEquals('End of stream reached',tsqlEOF,Parser.CurrentToken);
  1167. end;
  1168. function TTestSQLParser.GetParserOptions: TParserOptions;
  1169. begin
  1170. if Assigned(FParser) then
  1171. Result:=FParser.Options
  1172. else
  1173. Result:=FParserOptions;
  1174. end;
  1175. procedure TTestSQLParser.AssertTypeDefaults(TD : TSQLTypeDefinition;Len : Integer = 0);
  1176. begin
  1177. AssertNull(TD.DefaultValue);
  1178. AssertNull(TD.Check);
  1179. AssertNull(TD.Collation);
  1180. AssertEquals('Array dim 0',0,Length(TD.ArrayDims));
  1181. AssertEquals('Blob type 0',0,TD.BlobType);
  1182. AssertEquals('Not required',False,TD.NotNull);
  1183. AssertEquals('Length',Len,TD.Len);
  1184. end;
  1185. procedure TTestSQLParser.TestDropStatement(const ASource: string;
  1186. C: TSQLElementClass);
  1187. Var
  1188. D : TSQLDropStatement;
  1189. begin
  1190. If ASOURCE='SHADOW' then
  1191. CreateParser('DROP '+ASource+' 1')
  1192. else
  1193. CreateParser('DROP '+ASource+' A');
  1194. FToFree:=Parser.Parse;
  1195. AssertNotNull('Parse returns result',FTofree);
  1196. If Not FToFree.InheritsFrom(TSQLDropStatement) then
  1197. Fail('Drop statement is not of type TSQLDropStatement');
  1198. CheckClass(FToFree ,C);
  1199. D:=TSQLDropStatement(FToFree);
  1200. If ASOURCE='SHADOW' then
  1201. AssertIdentifierName('object name','1',D.ObjectName)
  1202. else
  1203. AssertIdentifierName('object name','A',D.ObjectName);
  1204. end;
  1205. function TTestSQLParser.TestCreateStatement(const ASource,AName: string;
  1206. C: TSQLElementClass): TSQLCreateOrAlterStatement;
  1207. begin
  1208. CreateParser(ASource);
  1209. FToFree:=Parser.Parse;
  1210. AssertNotNull('Parse returns result',FTofree);
  1211. If Not FToFree.InheritsFrom(TSQLCreateOrAlterStatement) then
  1212. Fail('create statement is not of type TSQLCreateOrAlterStatement');
  1213. CheckClass(FToFree ,C);
  1214. Result:=TSQLCreateOrAlterStatement(FToFree);
  1215. AssertIdentifierName('Correct identifier',AName,Result.ObjectName);
  1216. AssertEquals('End of stream reached',tsqlEOF,Parser.CurrentToken);
  1217. end;
  1218. { --------------------------------------------------------------------
  1219. TTestDropParser
  1220. --------------------------------------------------------------------}
  1221. procedure TTestDropParser.TestDropDatabase;
  1222. begin
  1223. TestDropStatement('DATABASE',TSQLDropDatabaseStatement);
  1224. end;
  1225. procedure TTestDropParser.TestDropDomain;
  1226. begin
  1227. TestDropStatement('DOMAIN',TSQLDropDomainStatement);
  1228. end;
  1229. procedure TTestDropParser.TestDropException;
  1230. begin
  1231. TestDropStatement('EXCEPTION',TSQLDropExceptionStatement);
  1232. end;
  1233. procedure TTestDropParser.TestDropGenerator;
  1234. begin
  1235. TestDropStatement('GENERATOR',TSQLDropGeneratorStatement);
  1236. end;
  1237. procedure TTestDropParser.TestDropIndex;
  1238. begin
  1239. TestDropStatement('INDEX',TSQLDropIndexStatement);
  1240. end;
  1241. procedure TTestDropParser.TestDropProcedure;
  1242. begin
  1243. TestDropStatement('PROCEDURE',TSQLDropProcedureStatement);
  1244. end;
  1245. procedure TTestDropParser.TestDropRole;
  1246. begin
  1247. TestDropStatement('ROLE',TSQLDropRoleStatement);
  1248. end;
  1249. procedure TTestDropParser.TestDropTable;
  1250. begin
  1251. TestDropStatement('TABLE',TSQLDropTableStatement);
  1252. end;
  1253. procedure TTestDropParser.TestDropTrigger;
  1254. begin
  1255. TestDropStatement('TRIGGER',TSQLDropTriggerStatement);
  1256. end;
  1257. procedure TTestDropParser.TestDropView;
  1258. begin
  1259. TestDropStatement('VIEW',TSQLDropViewStatement);
  1260. end;
  1261. procedure TTestDropParser.TestDropShadow;
  1262. begin
  1263. TestDropStatement('SHADOW',TSQLDropShadowStatement);
  1264. end;
  1265. procedure TTestDropParser.TestDropExternalFunction;
  1266. begin
  1267. TestDropStatement('EXTERNAL FUNCTION',TSQLDropExternalFunctionStatement);
  1268. end;
  1269. { --------------------------------------------------------------------
  1270. TTestGeneratorParser
  1271. --------------------------------------------------------------------}
  1272. procedure TTestGeneratorParser.TestCreateGenerator;
  1273. begin
  1274. TestCreateStatement('CREATE GENERATOR A','A',TSQLCreateGeneratorStatement);
  1275. end;
  1276. procedure TTestGeneratorParser.TestCreateSequence;
  1277. Var
  1278. C : TSQLCreateOrAlterStatement;
  1279. begin
  1280. C:=TestCreateStatement('CREATE SEQUENCE A','A',TSQLCreateGeneratorStatement);
  1281. AssertEquals('Sequence detected',True,TSQLCreateGeneratorStatement(c).IsSequence);
  1282. end;
  1283. procedure TTestGeneratorParser.TestAlterSequence;
  1284. Var
  1285. C : TSQLCreateOrAlterStatement;
  1286. D : TSQLAlterGeneratorStatement absolute C;
  1287. begin
  1288. C:=TestCreateStatement('ALTER SEQUENCE A RESTART WITH 100','A',TSQLAlterGeneratorStatement);
  1289. AssertEquals('Sequence detected',True,D.IsSequence);
  1290. AssertEquals('Sequence restart ',True,D.HasRestart);
  1291. AssertEquals('Sequence restart value',100,D.Restart);
  1292. end;
  1293. procedure TTestGeneratorParser.TestSetGenerator;
  1294. Var
  1295. S : TSQLSetGeneratorStatement;
  1296. begin
  1297. CreateParser('SET GENERATOR A TO 1');
  1298. FToFree:=Parser.Parse;
  1299. S:=TSQLSetGeneratorStatement(CheckClass(FToFree,TSQLSetGeneratorStatement));
  1300. AssertIdentifierName('Correct generator name','A',S.Objectname);
  1301. AssertEquals('New value',1,S.NewValue);
  1302. AssertEquals('End of stream reached',tsqlEOF,Parser.CurrentToken);
  1303. end;
  1304. { --------------------------------------------------------------------
  1305. TTestTypeParser
  1306. --------------------------------------------------------------------}
  1307. procedure TTestTypeParser.TestStringType1;
  1308. begin
  1309. TestStringDef('CHAR(1)',sdtChar,1);
  1310. end;
  1311. procedure TTestTypeParser.TestStringType2;
  1312. begin
  1313. TestStringDef('CHAR',sdtChar,0);
  1314. end;
  1315. procedure TTestTypeParser.TestStringType3;
  1316. begin
  1317. TestStringDef('CHARACTER',sdtChar,0);
  1318. end;
  1319. procedure TTestTypeParser.TestStringType4;
  1320. begin
  1321. TestStringDef('CHARACTER VARYING',sdtVarChar,0);
  1322. end;
  1323. procedure TTestTypeParser.TestStringType5;
  1324. begin
  1325. TestStringDef('VARCHAR',sdtVarChar,0);
  1326. end;
  1327. procedure TTestTypeParser.TestStringType6;
  1328. begin
  1329. TestStringDef('VARCHAR(2)',sdtVarChar,2);
  1330. end;
  1331. procedure TTestTypeParser.TestStringType7;
  1332. begin
  1333. TestStringDef('CHARACTER VARYING (2)',sdtVarChar,2);
  1334. end;
  1335. procedure TTestTypeParser.TestStringType8;
  1336. begin
  1337. TestStringDef('NATIONAL CHARACTER VARYING (2)',sdtNVarChar,2);
  1338. end;
  1339. procedure TTestTypeParser.TestStringType9;
  1340. begin
  1341. TestStringDef('NATIONAL CHARACTER (2)',sdtNChar,2);
  1342. end;
  1343. procedure TTestTypeParser.TestStringType10;
  1344. begin
  1345. TestStringDef('NATIONAL CHARACTER',sdtNChar,0);
  1346. end;
  1347. procedure TTestTypeParser.TestStringType11;
  1348. begin
  1349. TestStringDef('NATIONAL CHARACTER VARYING',sdtNVarChar,0);
  1350. end;
  1351. procedure TTestTypeParser.TestStringType12;
  1352. begin
  1353. TestStringDef('NCHAR',sdtNChar,0);
  1354. end;
  1355. procedure TTestTypeParser.TestStringType13;
  1356. begin
  1357. TestStringDef('NCHAR(2)',sdtNChar,2);
  1358. end;
  1359. procedure TTestTypeParser.TestStringType14;
  1360. begin
  1361. TestStringDef('NCHAR VARYING(2)',sdtNVarChar,2);
  1362. end;
  1363. procedure TTestTypeParser.TestStringType15;
  1364. begin
  1365. TestStringDef('CHAR (15) CHARACTER SET UTF8',sdtChar,15,'UTF8');
  1366. end;
  1367. procedure TTestTypeParser.TestStringType16;
  1368. begin
  1369. TestStringDef('CHAR VARYING (15) CHARACTER SET UTF8',sdtVarChar,15,'UTF8');
  1370. end;
  1371. procedure TTestTypeParser.TestStringType17;
  1372. begin
  1373. TestStringDef('CHAR VARYING CHARACTER SET UTF8',sdtVarChar,0,'UTF8');
  1374. end;
  1375. procedure TTestTypeParser.TestStringType18;
  1376. begin
  1377. TestStringDef('CHARACTER CHARACTER SET UTF8',sdtChar,0,'UTF8');
  1378. end;
  1379. procedure TTestTypeParser.TestStringType19;
  1380. Var
  1381. T : TSQLTypeDefinition;
  1382. begin
  1383. T:=TestType('CHAR(10) COLLATE UTF8',[],sdtChar);
  1384. AssertNotNull('Have collation',T.Collation);
  1385. AssertEquals('Correct collation','UTF8',T.Collation.Name);
  1386. end;
  1387. procedure TTestTypeParser.TestStringTypeErrors1;
  1388. begin
  1389. FErrSource:='VARCHAR VARYING';
  1390. AssertException(ESQLParser,@TestStringError);
  1391. end;
  1392. procedure TTestTypeParser.TestStringTypeErrors2;
  1393. begin
  1394. FErrSource:='CHAR(A)';
  1395. AssertException(ESQLParser,@TestStringError);
  1396. end;
  1397. procedure TTestTypeParser.TestStringTypeErrors3;
  1398. begin
  1399. FErrSource:='CHAR(1]';
  1400. AssertException(ESQLParser,@TestStringError);
  1401. end;
  1402. procedure TTestTypeParser.TestTypeInt1;
  1403. Var
  1404. TD : TSQLTypeDefinition;
  1405. begin
  1406. TD:=TestType('INT',[],sdtInteger);
  1407. AssertTypeDefaults(TD);
  1408. end;
  1409. procedure TTestTypeParser.TestTypeInt2;
  1410. Var
  1411. TD : TSQLTypeDefinition;
  1412. begin
  1413. TD:=TestType('INT DEFAULT NULL',[],sdtInteger);
  1414. AssertNotNull('Have Default value',TD.DefaultValue);
  1415. CheckClass(TD.DefaultValue,TSQLNullLiteral);
  1416. AssertEquals('End of stream reached',tsqlEOF,Parser.CurrentToken);
  1417. end;
  1418. procedure TTestTypeParser.TestTypeInt3;
  1419. Var
  1420. TD : TSQLTypeDefinition;
  1421. begin
  1422. TD:=TestType('INT DEFAULT 1',[],sdtInteger);
  1423. AssertNotNull('Have Default value',TD.DefaultValue);
  1424. CheckClass(TD.DefaultValue,TSQLIntegerLiteral);
  1425. AssertEquals('Correct default value ',1,TSQLIntegerLiteral(TD.DefaultValue).Value);
  1426. AssertEquals('End of stream reached',tsqlEOF,Parser.CurrentToken);
  1427. end;
  1428. procedure TTestTypeParser.TestTypeInt4;
  1429. Var
  1430. TD : TSQLTypeDefinition;
  1431. begin
  1432. TD:=TestType('INT NOT NULL',[],sdtInteger);
  1433. AssertNull('No Default value',TD.DefaultValue);
  1434. AssertEquals('Required field',True,TD.NotNull);
  1435. AssertEquals('End of stream reached',tsqlEOF,Parser.CurrentToken);
  1436. end;
  1437. procedure TTestTypeParser.TestTypeInt5;
  1438. Var
  1439. TD : TSQLTypeDefinition;
  1440. begin
  1441. TD:=TestType('INT [3]',[],sdtInteger);
  1442. AssertEquals('Array of length',1,Length(TD.ArrayDims));
  1443. AssertEquals('Upper bound',3,TD.ArrayDims[0][2]);
  1444. AssertEquals('Lower bound',1,TD.ArrayDims[0][1]);
  1445. AssertEquals('End of stream reached',tsqlEOF,Parser.CurrentToken);
  1446. end;
  1447. procedure TTestTypeParser.TestNumerical1;
  1448. Var
  1449. TD : TSQLTypeDefinition;
  1450. begin
  1451. TD:=TestType('NUMERIC (10)',[],sdtNumeric);
  1452. AssertEquals('Correct length',10,TD.Len);
  1453. end;
  1454. procedure TTestTypeParser.TestNumerical2;
  1455. Var
  1456. TD : TSQLTypeDefinition;
  1457. begin
  1458. TD:=TestType('NUMERIC (10,3)',[],sdtNumeric);
  1459. AssertEquals('Correct length',10,TD.Len);
  1460. AssertEquals('Correct scale',3,TD.Scale);
  1461. end;
  1462. procedure TTestTypeParser.TestNumerical3;
  1463. Var
  1464. TD : TSQLTypeDefinition;
  1465. begin
  1466. TD:=TestType('NUMERIC',[],sdtNumeric);
  1467. AssertEquals('Correct length',0,TD.Len);
  1468. AssertEquals('Correct scale',0,TD.Scale);
  1469. end;
  1470. procedure TTestTypeParser.TestNumericalError1;
  1471. begin
  1472. FErrSource:='NUMERIC ()';
  1473. AssertException(ESQLParser,@TestTypeError);
  1474. end;
  1475. procedure TTestTypeParser.TestNumericalError2;
  1476. begin
  1477. FErrSource:='NUMERIC (A)';
  1478. AssertException(ESQLParser,@TestTypeError);
  1479. end;
  1480. procedure TTestTypeParser.TestNumericalError3;
  1481. begin
  1482. FErrSource:='NUMERIC (,1)';
  1483. AssertException(ESQLParser,@TestTypeError);
  1484. end;
  1485. procedure TTestTypeParser.TestNumericalError4;
  1486. begin
  1487. FErrSource:='NUMERIC (1,)';
  1488. AssertException(ESQLParser,@TestTypeError);
  1489. end;
  1490. procedure TTestTypeParser.TestNumericalError5;
  1491. begin
  1492. FErrSource:='NUMERIC (1';
  1493. AssertException(ESQLParser,@TestTypeError);
  1494. end;
  1495. procedure TTestTypeParser.TestNumericalError6;
  1496. begin
  1497. FErrSource:='NUMERIC (1,';
  1498. AssertException(ESQLParser,@TestTypeError);
  1499. end;
  1500. procedure TTestTypeParser.TestNumericalError7;
  1501. begin
  1502. FErrSource:='NUMERIC (1 NOT';
  1503. AssertException(ESQLParser,@TestTypeError);
  1504. end;
  1505. procedure TTestTypeParser.TestBlob1;
  1506. Var
  1507. TD : TSQLTypeDefinition;
  1508. begin
  1509. TD:=TestType('BLOB sub_type 1 SEGMENT SIZE 80 CHARACTER SET UTF8',[],sdtBlob);
  1510. AssertEquals('Blob type 1',1,TD.BlobType);
  1511. AssertEquals('Blob segment size',80,TD.Len);
  1512. AssertEquals('Character set','UTF8',TD.Charset);
  1513. end;
  1514. procedure TTestTypeParser.TestBlob2;
  1515. Var
  1516. TD : TSQLTypeDefinition;
  1517. begin
  1518. TD:=TestType('BLOB (80,1) CHARACTER SET UTF8',[],sdtBlob);
  1519. AssertEquals('Blob type 1',1,TD.BlobType);
  1520. AssertEquals('Blob segment size',80,TD.Len);
  1521. AssertEquals('Character set','UTF8',TD.Charset);
  1522. end;
  1523. procedure TTestTypeParser.TestBlob3;
  1524. Var
  1525. TD : TSQLTypeDefinition;
  1526. begin
  1527. TD:=TestType('BLOB SEGMENT SIZE 80',[],sdtBlob);
  1528. AssertEquals('Blob type 0',0,TD.BlobType);
  1529. AssertEquals('Blob segment size',80,TD.Len);
  1530. AssertEquals('Character set','',TD.Charset);
  1531. end;
  1532. procedure TTestTypeParser.TestBlob4;
  1533. Var
  1534. TD : TSQLTypeDefinition;
  1535. begin
  1536. TD:=TestType('BLOB SUB_TYPE 1',[],sdtBlob);
  1537. AssertEquals('Blob type 1',1,TD.BlobType);
  1538. AssertEquals('Blob segment size',0,TD.Len);
  1539. AssertEquals('Character set','',TD.Charset);
  1540. end;
  1541. procedure TTestTypeParser.TestBlob5;
  1542. Var
  1543. TD : TSQLTypeDefinition;
  1544. begin
  1545. TD:=TestType('BLOB (80)',[],sdtBlob);
  1546. AssertEquals('Blob type 0',0,TD.BlobType);
  1547. AssertEquals('Blob segment size',80,TD.Len);
  1548. AssertEquals('Character set','',TD.Charset);
  1549. end;
  1550. procedure TTestTypeParser.TestBlob6;
  1551. Var
  1552. TD : TSQLTypeDefinition;
  1553. begin
  1554. TD:=TestType('BLOB',[],sdtBlob);
  1555. AssertEquals('Blob type 0',0,TD.BlobType);
  1556. AssertEquals('Blob segment size',0,TD.Len);
  1557. AssertEquals('Character set','',TD.Charset);
  1558. end;
  1559. procedure TTestTypeParser.TestBlob7;
  1560. var
  1561. TD : TSQLTypeDefinition;
  1562. begin
  1563. TD:=TestType('BLOB SUB_TYPE BINARY',[],sdtBlob);
  1564. AssertEquals('Blob type 0',0,TD.BlobType);
  1565. AssertEquals('Blob segment size',0,TD.Len);
  1566. AssertEquals('Character set','',TD.Charset);
  1567. end;
  1568. procedure TTestTypeParser.TestBlob8;
  1569. var
  1570. TD : TSQLTypeDefinition;
  1571. begin
  1572. TD:=TestType('BLOB SUB_TYPE TEXT',[],sdtBlob);
  1573. AssertEquals('Blob type 1',1,TD.BlobType);
  1574. AssertEquals('Blob segment size',0,TD.Len);
  1575. AssertEquals('Character set','',TD.Charset);
  1576. end;
  1577. procedure TTestTypeParser.TestSmallInt;
  1578. begin
  1579. TestType('SMALLINT',[],sdtSmallint);
  1580. end;
  1581. procedure TTestTypeParser.TestFloat;
  1582. begin
  1583. TestType('FLOAT',[],sdtFloat);
  1584. end;
  1585. procedure TTestTypeParser.TestDoublePrecision;
  1586. begin
  1587. TestType('DOUBLE PRECISION',[],sdtDoublePrecision);
  1588. end;
  1589. procedure TTestTypeParser.TestDoublePrecisionDefault;
  1590. begin
  1591. TestType('DOUBLE PRECISION DEFAULT 0',[],sdtDoublePrecision);
  1592. end;
  1593. procedure TTestTypeParser.TestBlobError1;
  1594. begin
  1595. FerrSource:='BLOB (1,)';
  1596. AssertException(ESQLParser,@TestTypeError);
  1597. end;
  1598. procedure TTestTypeParser.TestBlobError2;
  1599. begin
  1600. FerrSource:='BLOB 1,)';
  1601. // EAssertionfailed, due to not EOF
  1602. AssertException(EAssertionFailedError,@TestTypeError);
  1603. end;
  1604. procedure TTestTypeParser.TestBlobError3;
  1605. begin
  1606. FerrSource:='BLOB (80) SUB_TYPE 3';
  1607. AssertException(ESQLParser,@TestTypeError);
  1608. end;
  1609. procedure TTestTypeParser.TestBlobError4;
  1610. begin
  1611. FerrSource:='BLOB CHARACTER UTF8';
  1612. AssertException(ESQLParser,@TestTypeError);
  1613. end;
  1614. procedure TTestTypeParser.TestBlobError5;
  1615. begin
  1616. FerrSource:='BLOB (80) SEGMENT SIZE 80';
  1617. AssertException(ESQLParser,@TestTypeError);
  1618. end;
  1619. procedure TTestTypeParser.TestBlobError6;
  1620. begin
  1621. FerrSource:='BLOB (A)';
  1622. AssertException(ESQLParser,@TestTypeError);
  1623. end;
  1624. procedure TTestTypeParser.TestBlobError7;
  1625. begin
  1626. FerrSource:='BLOB (1';
  1627. AssertException(ESQLParser,@TestTypeError);
  1628. end;
  1629. { --------------------------------------------------------------------
  1630. TTestCheckParser
  1631. --------------------------------------------------------------------}
  1632. procedure TTestCheckParser.TestCheckNotNull;
  1633. Var
  1634. B : TSQLBinaryExpression;
  1635. begin
  1636. B:=TSQLBinaryExpression(TestCheck('VALUE IS NOT NULL',TSQLBinaryExpression));
  1637. AssertEquals('IS NOT operator,',boISNot,B.Operation);
  1638. AssertLiteralExpr('Left is value',B.Left,TSQLValueLiteral);
  1639. AssertLiteralExpr('Right is null',B.Right,TSQLNullLiteral);
  1640. end;
  1641. procedure TTestCheckParser.TestCheckNull;
  1642. Var
  1643. B : TSQLBinaryExpression;
  1644. begin
  1645. B:=TSQLBinaryExpression(TestCheck('VALUE IS NULL',TSQLBinaryExpression));
  1646. AssertEquals('IS operator,',boIS,B.Operation);
  1647. AssertLiteralExpr('Left is value',B.Left,TSQLValueLiteral);
  1648. AssertLiteralExpr('Right is null',B.Right,TSQLNullLiteral);
  1649. end;
  1650. procedure TTestCheckParser.TestCheckBraces;
  1651. Var
  1652. B : TSQLBinaryExpression;
  1653. begin
  1654. B:=TSQLBinaryExpression(TestCheck('(VALUE IS NULL)',TSQLBinaryExpression));
  1655. AssertEquals('IS operator,',boIS,B.Operation);
  1656. AssertLiteralExpr('Left is value',B.Left,TSQLValueLiteral);
  1657. AssertLiteralExpr('Right is null',B.Right,TSQLNullLiteral);
  1658. end;
  1659. procedure TTestCheckParser.TestCheckBracesError;
  1660. begin
  1661. FErrSource:='(VALUE IS NOT NULL ME )';
  1662. AssertException('Error in braces.', ESQLParser,@TestCheckError);
  1663. end;
  1664. procedure TTestCheckParser.TestCheckParamError;
  1665. begin
  1666. FErrSource:='VALUE <> :P';
  1667. AssertException('Parameter.', ESQLParser,@TestCheckError);
  1668. end;
  1669. procedure TTestCheckParser.TestCheckIdentifierError;
  1670. begin
  1671. FErrSource:='(X IS NOT NULL)';
  1672. AssertException('Error in check: identifier.', ESQLParser,@TestCheckError);
  1673. end;
  1674. procedure TTestCheckParser.TestIsEqual;
  1675. Var
  1676. B : TSQLBinaryExpression;
  1677. begin
  1678. B:=TSQLBinaryExpression(TestCheck('VALUE = 3',TSQLBinaryExpression));
  1679. AssertEquals('Equal operator',boEq,B.Operation);
  1680. AssertLiteralExpr('Left is value',B.Left,TSQLValueLiteral);
  1681. AssertLiteralExpr('Right is integer',B.Right,TSQLIntegerLiteral);
  1682. end;
  1683. procedure TTestCheckParser.TestIsNotEqual1;
  1684. Var
  1685. B : TSQLBinaryExpression;
  1686. begin
  1687. B:=TSQLBinaryExpression(TestCheck('VALUE <> 3',TSQLBinaryExpression));
  1688. AssertEquals('Not Equal operator',boNE,B.Operation);
  1689. AssertLiteralExpr('Left is value',B.Left,TSQLValueLiteral);
  1690. AssertLiteralExpr('Right is integer',B.Right,TSQLIntegerLiteral);
  1691. end;
  1692. procedure TTestCheckParser.TestIsNotEqual2;
  1693. Var
  1694. B : TSQLBinaryExpression;
  1695. begin
  1696. B:=TSQLBinaryExpression(TestCheck('VALUE != 3',TSQLBinaryExpression));
  1697. AssertEquals('ENot qual operator',boNE,B.Operation);
  1698. AssertLiteralExpr('Left is value',B.Left,TSQLValueLiteral);
  1699. AssertLiteralExpr('Right is integer',B.Right,TSQLIntegerLiteral);
  1700. end;
  1701. procedure TTestCheckParser.TestGreaterThan;
  1702. Var
  1703. B : TSQLBinaryExpression;
  1704. begin
  1705. B:=TSQLBinaryExpression(TestCheck('VALUE > 3',TSQLBinaryExpression));
  1706. AssertEquals('Greater than operator',boGT,B.Operation);
  1707. AssertLiteralExpr('Left is value',B.Left,TSQLValueLiteral);
  1708. AssertLiteralExpr('Right is integer',B.Right,TSQLIntegerLiteral);
  1709. end;
  1710. procedure TTestCheckParser.TestGreaterThanEqual1;
  1711. Var
  1712. B : TSQLBinaryExpression;
  1713. begin
  1714. B:=TSQLBinaryExpression(TestCheck('VALUE >= 3',TSQLBinaryExpression));
  1715. AssertEquals('Greater or Equal operator',boGE,B.Operation);
  1716. AssertLiteralExpr('Left is value',B.Left,TSQLValueLiteral);
  1717. AssertLiteralExpr('Right is integer',B.Right,TSQLIntegerLiteral);
  1718. end;
  1719. procedure TTestCheckParser.TestGreaterThanEqual2;
  1720. Var
  1721. B : TSQLBinaryExpression;
  1722. begin
  1723. B:=TSQLBinaryExpression(TestCheck('VALUE !< 3',TSQLBinaryExpression));
  1724. AssertEquals('Greater or Equal operator',boGE,B.Operation);
  1725. AssertLiteralExpr('Left is value',B.Left,TSQLValueLiteral);
  1726. AssertLiteralExpr('Right is integer',B.Right,TSQLIntegerLiteral);
  1727. end;
  1728. procedure TTestCheckParser.TestLessThan;
  1729. Var
  1730. B : TSQLBinaryExpression;
  1731. begin
  1732. B:=TSQLBinaryExpression(TestCheck('VALUE < 3',TSQLBinaryExpression));
  1733. AssertEquals('Less than operator',boLT,B.Operation);
  1734. AssertLiteralExpr('Left is value',B.Left,TSQLValueLiteral);
  1735. AssertLiteralExpr('Right is integer',B.Right,TSQLIntegerLiteral);
  1736. end;
  1737. procedure TTestCheckParser.TestLessThanEqual1;
  1738. Var
  1739. B : TSQLBinaryExpression;
  1740. begin
  1741. B:=TSQLBinaryExpression(TestCheck('VALUE <= 3',TSQLBinaryExpression));
  1742. AssertEquals('Less or Equal operator',boLE,B.Operation);
  1743. AssertLiteralExpr('Left is value',B.Left,TSQLValueLiteral);
  1744. AssertLiteralExpr('Right is integer',B.Right,TSQLIntegerLiteral);
  1745. end;
  1746. procedure TTestCheckParser.TestLessThanEqual2;
  1747. Var
  1748. B : TSQLBinaryExpression;
  1749. begin
  1750. B:=TSQLBinaryExpression(TestCheck('VALUE !> 3',TSQLBinaryExpression));
  1751. AssertEquals('Less or Equal operator',boLE,B.Operation);
  1752. AssertLiteralExpr('Left is value',B.Left,TSQLValueLiteral);
  1753. AssertLiteralExpr('Right is integer',B.Right,TSQLIntegerLiteral);
  1754. end;
  1755. procedure TTestCheckParser.TestLike;
  1756. Var
  1757. B : TSQLBinaryExpression;
  1758. begin
  1759. B:=TSQLBinaryExpression(TestCheck('VALUE LIKE ''%3''',TSQLBinaryExpression));
  1760. AssertEquals('Like operator',boLike,B.Operation);
  1761. AssertLiteralExpr('Left is value',B.Left,TSQLValueLiteral);
  1762. AssertLiteralExpr('Right is string',B.Right,TSQLStringLiteral);
  1763. end;
  1764. procedure TTestCheckParser.TestNotLike;
  1765. Var
  1766. B : TSQLBinaryExpression;
  1767. U : TSQLUnaryExpression;
  1768. begin
  1769. U:=TSQLUnaryExpression(TestCheck('VALUE NOT LIKE ''%3''',TSQLUnaryExpression));
  1770. AssertEquals('Like operator',uoNot,U.Operation);
  1771. CheckClass(U.Operand,TSQLBinaryExpression);
  1772. B:=TSQLBinaryExpression(U.Operand);
  1773. AssertEquals('Like operator',boLike,B.Operation);
  1774. AssertLiteralExpr('Left is value',B.Left,TSQLValueLiteral);
  1775. AssertLiteralExpr('Right is string',B.Right,TSQLStringLiteral);
  1776. end;
  1777. procedure TTestCheckParser.TestContaining;
  1778. Var
  1779. B : TSQLBinaryExpression;
  1780. begin
  1781. B:=TSQLBinaryExpression(TestCheck('VALUE CONTAINING ''3''',TSQLBinaryExpression));
  1782. AssertEquals('Like operator',boContaining,B.Operation);
  1783. AssertLiteralExpr('Left is value',B.Left,TSQLValueLiteral);
  1784. AssertLiteralExpr('Right is string',B.Right,TSQLStringLiteral);
  1785. end;
  1786. procedure TTestCheckParser.TestDivide;
  1787. Var
  1788. B : TSQLBinaryExpression;
  1789. begin
  1790. B:=TSQLBinaryExpression(TestCheck('VALUE / 1',TSQLBinaryExpression));
  1791. AssertEquals('Correct operator', boDivide, B.Operation);
  1792. AssertLiteralExpr('Left is value',B.Left,TSQLValueLiteral);
  1793. AssertLiteralExpr('Right is integer',B.Right,TSQLIntegerLiteral);
  1794. AssertEquals('Right is 1',1, TSQLIntegerLiteral(TSQLLiteralExpression(B.Right).Literal).Value);
  1795. end;
  1796. procedure TTestCheckParser.TestNotContaining;
  1797. Var
  1798. B : TSQLBinaryExpression;
  1799. U : TSQLUnaryExpression;
  1800. begin
  1801. U:=TSQLUnaryExpression(TestCheck('VALUE NOT CONTAINING ''3''',TSQLUnaryExpression));
  1802. AssertEquals('Like operator',uoNot,U.Operation);
  1803. CheckClass(U.Operand,TSQLBinaryExpression);
  1804. B:=TSQLBinaryExpression(U.Operand);
  1805. AssertEquals('Like operator',boContaining,B.Operation);
  1806. AssertLiteralExpr('Left is value',B.Left,TSQLValueLiteral);
  1807. AssertLiteralExpr('Right is string',B.Right,TSQLStringLiteral);
  1808. end;
  1809. procedure TTestCheckParser.TestStarting;
  1810. Var
  1811. B : TSQLBinaryExpression;
  1812. begin
  1813. B:=TSQLBinaryExpression(TestCheck('VALUE STARTING ''3''',TSQLBinaryExpression));
  1814. AssertEquals('Starting operator',boStarting,B.Operation);
  1815. AssertLiteralExpr('Left is value',B.Left,TSQLValueLiteral);
  1816. AssertLiteralExpr('Right is string',B.Right,TSQLStringLiteral);
  1817. end;
  1818. procedure TTestCheckParser.TestNotStarting;
  1819. Var
  1820. B : TSQLBinaryExpression;
  1821. U : TSQLUnaryExpression;
  1822. begin
  1823. U:=TSQLUnaryExpression(TestCheck('VALUE NOT STARTING ''3''',TSQLUnaryExpression));
  1824. AssertEquals('Not operator',uoNot,U.Operation);
  1825. CheckClass(U.Operand,TSQLBinaryExpression);
  1826. B:=TSQLBinaryExpression(U.Operand);
  1827. AssertEquals('Starting operator',boStarting,B.Operation);
  1828. AssertLiteralExpr('Left is value',B.Left,TSQLValueLiteral);
  1829. AssertLiteralExpr('Right is string',B.Right,TSQLStringLiteral);
  1830. end;
  1831. procedure TTestCheckParser.TestStartingWith;
  1832. Var
  1833. B : TSQLBinaryExpression;
  1834. begin
  1835. B:=TSQLBinaryExpression(TestCheck('VALUE STARTING WITH ''3''',TSQLBinaryExpression));
  1836. AssertEquals('Starting operator',boStarting,B.Operation);
  1837. AssertLiteralExpr('Left is value',B.Left,TSQLValueLiteral);
  1838. AssertLiteralExpr('Right is string',B.Right,TSQLStringLiteral);
  1839. end;
  1840. procedure TTestCheckParser.TestSubtract;
  1841. Var
  1842. B : TSQLBinaryExpression;
  1843. begin
  1844. B:=TSQLBinaryExpression(TestCheck('VALUE - 1',TSQLBinaryExpression));
  1845. AssertEquals('Correct operator', boSubtract, B.Operation);
  1846. AssertLiteralExpr('Left is value',B.Left,TSQLValueLiteral);
  1847. AssertLiteralExpr('Right is integer',B.Right,TSQLIntegerLiteral);
  1848. AssertEquals('Right is 1',1, TSQLIntegerLiteral(TSQLLiteralExpression(B.Right).Literal).Value);
  1849. end;
  1850. procedure TTestCheckParser.TestNotStartingWith;
  1851. Var
  1852. B : TSQLBinaryExpression;
  1853. U : TSQLUnaryExpression;
  1854. begin
  1855. U:=TSQLUnaryExpression(TestCheck('VALUE NOT STARTING WITH ''3''',TSQLUnaryExpression));
  1856. AssertEquals('Not operator',uoNot,U.Operation);
  1857. CheckClass(U.Operand,TSQLBinaryExpression);
  1858. B:=TSQLBinaryExpression(U.Operand);
  1859. AssertEquals('Starting operator',boStarting,B.Operation);
  1860. AssertLiteralExpr('Left is value',B.Left,TSQLValueLiteral);
  1861. AssertLiteralExpr('Right is string',B.Right,TSQLStringLiteral);
  1862. end;
  1863. procedure TTestCheckParser.TestBetween;
  1864. Var
  1865. T : TSQLTernaryExpression;
  1866. begin
  1867. T:=TSQLTernaryExpression(TestCheck('VALUE BETWEEN 1 AND 5',TSQLTernaryExpression));
  1868. AssertEquals('Like operator',tobetween,T.Operation);
  1869. AssertLiteralExpr('Left is value',T.Left,TSQLValueLiteral);
  1870. AssertLiteralExpr('Middle is integer',T.Middle,TSQLIntegerLiteral);
  1871. AssertLiteralExpr('Right is integer',T.Right,TSQLIntegerLiteral);
  1872. end;
  1873. procedure TTestCheckParser.TestCase;
  1874. Var
  1875. T : TSQLCaseExpression;
  1876. B : TSQLBinaryExpression;
  1877. R : TSQLIdentifierName;
  1878. begin
  1879. T:=TSQLCaseExpression(TestCheck('CASE WHEN A=1 THEN "a" WHEN B=2 THEN "b" ELSE "c" END',TSQLCaseExpression));
  1880. AssertEquals('Branch count = 2',2,T.BranchCount);
  1881. AssertNotNull('Else branch exists',T.ElseBranch);
  1882. B:=(T.Branches[0].Condition as TSQLBinaryExpression);
  1883. R:=(T.Branches[0].Expression as TSQLIdentifierExpression).Identifier;
  1884. AssertEquals('First WHEN Identifier is A', 'A', (B.Left as TSQLIdentifierExpression).Identifier.Name);
  1885. AssertEquals('First WHEN Number is 1', 1, ((B.Right as TSQLLiteralExpression).Literal as TSQLIntegerLiteral).Value);
  1886. AssertEquals('First THEN result is "a"', 'a', R.Name);
  1887. B:=(T.Branches[1].Condition as TSQLBinaryExpression);
  1888. R:=(T.Branches[1].Expression as TSQLIdentifierExpression).Identifier;
  1889. AssertEquals('Second WHEN Identifier is B', 'B', (B.Left as TSQLIdentifierExpression).Identifier.Name);
  1890. AssertEquals('Second WHEN Number is 2', 2, ((B.Right as TSQLLiteralExpression).Literal as TSQLIntegerLiteral).Value);
  1891. AssertEquals('Second THEN result is "b"', 'b', R.Name);
  1892. R:=(T.ElseBranch as TSQLIdentifierExpression).Identifier;
  1893. AssertEquals('ELSE result is "c"', 'c', R.Name);
  1894. end;
  1895. procedure TTestCheckParser.TestNotBetween;
  1896. Var
  1897. U : TSQLUnaryExpression;
  1898. T : TSQLTernaryExpression;
  1899. begin
  1900. U:=TSQLUnaryExpression(TestCheck('VALUE NOT BETWEEN 1 AND 5',TSQLUnaryExpression));
  1901. AssertEquals('Not operator',uoNot,U.Operation);
  1902. CheckClass(U.Operand,TSQLTernaryExpression);
  1903. T:=TSQLTernaryExpression(U.Operand);
  1904. AssertEquals('Like operator',tobetween,T.Operation);
  1905. AssertLiteralExpr('Left is value',T.Left,TSQLValueLiteral);
  1906. AssertLiteralExpr('Middle is integer',T.Middle,TSQLIntegerLiteral);
  1907. AssertLiteralExpr('Right is integer',T.Right,TSQLIntegerLiteral);
  1908. end;
  1909. procedure TTestCheckParser.TestLikeEscape;
  1910. Var
  1911. T : TSQLTernaryExpression;
  1912. begin
  1913. T:=TSQLTernaryExpression(TestCheck('VALUE LIKE ''%2'' ESCAPE ''3''',TSQLTernaryExpression));
  1914. AssertEquals('Like operator',toLikeEscape,T.Operation);
  1915. AssertLiteralExpr('Left is value',T.Left,TSQLValueLiteral);
  1916. AssertLiteralExpr('Middle is string',T.Middle,TSQLStringLiteral);
  1917. AssertLiteralExpr('Right is string',T.Right,TSQLStringLiteral);
  1918. end;
  1919. procedure TTestCheckParser.TestMultiply;
  1920. Var
  1921. B : TSQLBinaryExpression;
  1922. begin
  1923. B:=TSQLBinaryExpression(TestCheck('VALUE * 1',TSQLBinaryExpression));
  1924. AssertEquals('Correct operator', boMultiply, B.Operation);
  1925. AssertLiteralExpr('Left is value',B.Left,TSQLValueLiteral);
  1926. AssertLiteralExpr('Right is integer',B.Right,TSQLIntegerLiteral);
  1927. AssertEquals('Right is 1',1, TSQLIntegerLiteral(TSQLLiteralExpression(B.Right).Literal).Value);
  1928. end;
  1929. procedure TTestCheckParser.TestNotLikeEscape;
  1930. Var
  1931. U : TSQLUnaryExpression;
  1932. T : TSQLTernaryExpression;
  1933. begin
  1934. U:=TSQLUnaryExpression(TestCheck('VALUE NOT LIKE ''%2'' ESCAPE ''3''',TSQLUnaryExpression));
  1935. AssertEquals('Not operator',uoNot,U.Operation);
  1936. CheckClass(U.Operand,TSQLTernaryExpression);
  1937. T:=TSQLTernaryExpression(U.Operand);
  1938. AssertEquals('Like operator',toLikeEscape,T.Operation);
  1939. AssertLiteralExpr('Left is value',T.Left,TSQLValueLiteral);
  1940. AssertLiteralExpr('Middle is string',T.Middle,TSQLStringLiteral);
  1941. AssertLiteralExpr('Right is string',T.Right,TSQLStringLiteral);
  1942. end;
  1943. procedure TTestCheckParser.TestAdd;
  1944. Var
  1945. B : TSQLBinaryExpression;
  1946. begin
  1947. B:=TSQLBinaryExpression(TestCheck('VALUE + 1',TSQLBinaryExpression));
  1948. AssertEquals('Correct operator', boAdd, B.Operation);
  1949. AssertLiteralExpr('Left is value',B.Left,TSQLValueLiteral);
  1950. AssertLiteralExpr('Right is integer',B.Right,TSQLIntegerLiteral);
  1951. AssertEquals('Right is 1',1, TSQLIntegerLiteral(TSQLLiteralExpression(B.Right).Literal).Value);
  1952. end;
  1953. procedure TTestCheckParser.TestAnd;
  1954. Var
  1955. T,B : TSQLBinaryExpression;
  1956. begin
  1957. T:=TSQLBinaryExpression(TestCheck('VALUE > 4 AND Value < 11',TSQLBinaryExpression));
  1958. AssertEquals('And operator',boand,T.Operation);
  1959. CheckClass(T.Left,TSQLBinaryExpression);
  1960. CheckClass(T.Right,TSQLBinaryExpression);
  1961. B:=TSQLBinaryExpression(T.Left);
  1962. AssertLiteralExpr('Left is value',B.Left,TSQLValueLiteral);
  1963. AssertEquals('Less than operator',boGT,B.Operation);
  1964. AssertLiteralExpr('Right is value',B.Right,TSQLIntegerLiteral);
  1965. B:=TSQLBinaryExpression(T.Right);
  1966. AssertLiteralExpr('Left is value',B.Left,TSQLValueLiteral);
  1967. AssertEquals('Less than operator',boLT,B.Operation);
  1968. AssertLiteralExpr('Right is value',B.Right,TSQLIntegerLiteral);
  1969. end;
  1970. procedure TTestCheckParser.TestOr;
  1971. Var
  1972. T,B : TSQLBinaryExpression;
  1973. begin
  1974. T:=TSQLBinaryExpression(TestCheck('VALUE < 4 or Value > 11',TSQLBinaryExpression));
  1975. AssertEquals('And operator',boor,T.Operation);
  1976. CheckClass(T.Left,TSQLBinaryExpression);
  1977. CheckClass(T.Right,TSQLBinaryExpression);
  1978. B:=TSQLBinaryExpression(T.Left);
  1979. AssertLiteralExpr('Left is value',B.Left,TSQLValueLiteral);
  1980. AssertEquals('Less than operator',boLT,B.Operation);
  1981. AssertLiteralExpr('Right is value',B.Right,TSQLIntegerLiteral);
  1982. B:=TSQLBinaryExpression(T.Right);
  1983. AssertLiteralExpr('Left is value',B.Left,TSQLValueLiteral);
  1984. AssertEquals('Less than operator',boGT,B.Operation);
  1985. AssertLiteralExpr('Right is value',B.Right,TSQLIntegerLiteral);
  1986. end;
  1987. procedure TTestCheckParser.TestNotOr;
  1988. Var
  1989. T,B : TSQLBinaryExpression;
  1990. begin
  1991. T:=TSQLBinaryExpression(TestCheck('VALUE IS NOT NULL or Value > 11',TSQLBinaryExpression));
  1992. AssertEquals('And operator',boor,T.Operation);
  1993. CheckClass(T.Left,TSQLBinaryExpression);
  1994. CheckClass(T.Right,TSQLBinaryExpression);
  1995. B:=TSQLBinaryExpression(T.Left);
  1996. AssertLiteralExpr('Left is value',B.Left,TSQLValueLiteral);
  1997. AssertEquals('Is not null operator',boisNot,B.Operation);
  1998. AssertLiteralExpr('Right is value',B.Right,TSQLNullLiteral);
  1999. B:=TSQLBinaryExpression(T.Right);
  2000. AssertLiteralExpr('Left is value',B.Left,TSQLValueLiteral);
  2001. AssertEquals('Less than operator',boGT,B.Operation);
  2002. AssertLiteralExpr('Right is value',B.Right,TSQLIntegerLiteral);
  2003. end;
  2004. { TTestDomainParser }
  2005. procedure TTestDomainParser.TestSimpleDomain;
  2006. Var
  2007. P : TSQLCreateOrAlterStatement;
  2008. D : TSQLCreateDomainStatement;
  2009. T : TSQLTypeDefinition;
  2010. begin
  2011. P:=TestCreateStatement('CREATE DOMAIN A INT','A',TSQLCreateDomainStatement);
  2012. CheckClass(P,TSQLCreateDomainStatement);
  2013. D:=TSQLCreateDomainStatement(P);
  2014. AssertNotNull('Have type Definition',D.TypeDefinition);
  2015. T:=D.TypeDefinition;
  2016. AssertTypeDefaults(T);
  2017. AssertEquals('Integer data type',sdtInteger,T.DataType);
  2018. end;
  2019. procedure TTestDomainParser.TestSimpleDomainAs;
  2020. Var
  2021. P : TSQLCreateOrAlterStatement;
  2022. D : TSQLCreateDomainStatement;
  2023. T : TSQLTypeDefinition;
  2024. begin
  2025. P:=TestCreateStatement('CREATE DOMAIN A AS INT','A',TSQLCreateDomainStatement);
  2026. CheckClass(P,TSQLCreateDomainStatement);
  2027. D:=TSQLCreateDomainStatement(P);
  2028. AssertNotNull('Have type Definition',D.TypeDefinition);
  2029. T:=D.TypeDefinition;
  2030. AssertTypeDefaults(T);
  2031. AssertEquals('Integer data type',sdtInteger,T.DataType);
  2032. end;
  2033. procedure TTestDomainParser.TestNotNullDomain;
  2034. Var
  2035. P : TSQLCreateOrAlterStatement;
  2036. D : TSQLCreateDomainStatement;
  2037. T : TSQLTypeDefinition;
  2038. begin
  2039. P:=TestCreateStatement('CREATE DOMAIN A INT NOT NULL','A',TSQLCreateDomainStatement);
  2040. CheckClass(P,TSQLCreateDomainStatement);
  2041. D:=TSQLCreateDomainStatement(P);
  2042. AssertNotNull('Have type Definition',D.TypeDefinition);
  2043. T:=D.TypeDefinition;
  2044. AssertEquals('Integer data type',sdtInteger,T.DataType);
  2045. AssertEquals('Not null',True,T.NotNull);
  2046. end;
  2047. procedure TTestDomainParser.TestDefaultNotNullDomain;
  2048. Var
  2049. P : TSQLCreateOrAlterStatement;
  2050. D : TSQLCreateDomainStatement;
  2051. T : TSQLTypeDefinition;
  2052. begin
  2053. P:=TestCreateStatement('CREATE DOMAIN A INT DEFAULT 2 NOT NULL','A',TSQLCreateDomainStatement);
  2054. CheckClass(P,TSQLCreateDomainStatement);
  2055. D:=TSQLCreateDomainStatement(P);
  2056. AssertNotNull('Have type Definition',D.TypeDefinition);
  2057. T:=D.TypeDefinition;
  2058. AssertNotNull('Have default value',T.DefaultValue);
  2059. CheckClass(T.DefaultValue,TSQLINtegerLiteral);
  2060. AssertEquals('Integer data type',sdtInteger,T.DataType);
  2061. AssertEquals('Not null',True,T.NotNull);
  2062. end;
  2063. procedure TTestDomainParser.TestCheckDomain;
  2064. var
  2065. P : TSQLCreateOrAlterStatement;
  2066. D : TSQLCreateDomainStatement;
  2067. T : TSQLTypeDefinition;
  2068. begin
  2069. P:=TestCreateStatement('CREATE DOMAIN A AS CHAR(8) CHECK (VALUE STARTING WITH ''V'')','A',TSQLCreateDomainStatement);
  2070. CheckClass(P,TSQLCreateDomainStatement);
  2071. D:=TSQLCreateDomainStatement(P);
  2072. AssertNotNull('Have type Definition',D.TypeDefinition);
  2073. T:=D.TypeDefinition;
  2074. AssertNull('No default value',T.DefaultValue);
  2075. AssertEquals('Character data type',sdtChar,T.DataType);
  2076. AssertEquals('Not null must be allowed',False,T.NotNull);
  2077. end;
  2078. procedure TTestDomainParser.TestDefaultCheckNotNullDomain;
  2079. var
  2080. P : TSQLCreateOrAlterStatement;
  2081. D : TSQLCreateDomainStatement;
  2082. T : TSQLTypeDefinition;
  2083. begin
  2084. P:=TestCreateStatement(
  2085. 'CREATE DOMAIN DEFCHECKNOTN AS VARCHAR(1) DEFAULT ''s'' CHECK (VALUE IN (''s'',''h'',''A'')) NOT NULL',
  2086. 'DEFCHECKNOTN',TSQLCreateDomainStatement);
  2087. CheckClass(P,TSQLCreateDomainStatement);
  2088. D:=TSQLCreateDomainStatement(P);
  2089. AssertNotNull('Have type Definition',D.TypeDefinition);
  2090. T:=D.TypeDefinition;
  2091. AssertNotNull('Have default value',T.DefaultValue);
  2092. AssertEquals('Varchar data type',sdtVarChar,T.DataType);
  2093. AssertEquals('Not null',True,T.NotNull);
  2094. end;
  2095. procedure TTestDomainParser.TestAlterDomainDropDefault;
  2096. begin
  2097. TestCreateStatement('ALTER DOMAIN A DROP DEFAULT','A',TSQLAlterDomainDropDefaultStatement);
  2098. end;
  2099. procedure TTestDomainParser.TestAlterDomainDropCheck;
  2100. begin
  2101. TestCreateStatement('ALTER DOMAIN A DROP CONSTRAINT','A',TSQLAlterDomainDropCheckStatement);
  2102. end;
  2103. procedure TTestDomainParser.TestAlterDomainAddCheck;
  2104. Var
  2105. P : TSQLCreateOrAlterStatement;
  2106. D : TSQLAlterDomainAddCheckStatement;
  2107. B : TSQLBinaryExpression;
  2108. begin
  2109. P:=TestCreateStatement('ALTER DOMAIN A ADD CHECK (VALUE IS NOT NULL)','A',TSQLAlterDomainAddCheckStatement);
  2110. D:=TSQLAlterDomainAddCheckStatement(P);
  2111. AssertNotNull('Have check',D.Check);
  2112. CheckClass(D.Check,TSQLBinaryExpression);
  2113. B:=TSQLBinaryExpression(D.Check);
  2114. AssertEquals('Is not null operator',boIsNot,B.Operation);
  2115. AssertLiteralExpr('Left is value',B.Left,TSQLValueLiteral);
  2116. AssertEquals('Is not null operator',boisNot,B.Operation);
  2117. AssertLiteralExpr('Right is value',B.Right,TSQLNullLiteral);
  2118. end;
  2119. procedure TTestDomainParser.TestAlterDomainAddConstraintCheck;
  2120. Var
  2121. P : TSQLCreateOrAlterStatement;
  2122. D : TSQLAlterDomainAddCheckStatement;
  2123. B : TSQLBinaryExpression;
  2124. begin
  2125. P:=TestCreateStatement('ALTER DOMAIN A ADD CONSTRAINT CHECK (VALUE IS NOT NULL)','A',TSQLAlterDomainAddCheckStatement);
  2126. D:=TSQLAlterDomainAddCheckStatement(P);
  2127. AssertNotNull('Have check',D.Check);
  2128. CheckClass(D.Check,TSQLBinaryExpression);
  2129. B:=TSQLBinaryExpression(D.Check);
  2130. AssertEquals('Is not null operation',boIsNot,B.Operation);
  2131. AssertLiteralExpr('Left is value',B.Left,TSQLValueLiteral);
  2132. AssertEquals('Is not null operator',boisNot,B.Operation);
  2133. AssertLiteralExpr('Right is value',B.Right,TSQLNullLiteral);
  2134. end;
  2135. procedure TTestDomainParser.TestAlterDomainAddConstraintError;
  2136. begin
  2137. FErrSource:='ALTER DOMAIN A ADD CONSTRAINT (VALUE IS NOT NULL)';
  2138. AssertException(ESQLParser,@TestParseError);
  2139. end;
  2140. procedure TTestDomainParser.TestAlterDomainSetDefault;
  2141. Var
  2142. P : TSQLCreateOrAlterStatement;
  2143. D : TSQLAlterDomainSetDefaultStatement;
  2144. begin
  2145. P:=TestCreateStatement('ALTER DOMAIN A SET DEFAULT NULL','A',TSQLAlterDomainSetDefaultStatement);
  2146. D:=TSQLAlterDomainSetDefaultStatement(P);
  2147. AssertNotNull('Have default',D.DefaultValue);
  2148. CheckClass(D.DefaultValue,TSQLNullLiteral);
  2149. end;
  2150. procedure TTestDomainParser.TestAlterDomainRename;
  2151. Var
  2152. P : TSQLCreateOrAlterStatement;
  2153. D : TSQLAlterDomainRenameStatement;
  2154. begin
  2155. P:=TestCreateStatement('ALTER DOMAIN A B','A',TSQLAlterDomainRenameStatement);
  2156. D:=TSQLAlterDomainRenameStatement(P);
  2157. AssertIdentifierName('New name','B',D.NewName);
  2158. end;
  2159. procedure TTestDomainParser.TestAlterDomainNewType;
  2160. Var
  2161. P : TSQLCreateOrAlterStatement;
  2162. D : TSQLAlterDomainTypeStatement;
  2163. begin
  2164. P:=TestCreateStatement('ALTER DOMAIN A TYPE CHAR(10)','A',TSQLAlterDomainTypeStatement);
  2165. D:=TSQLAlterDomainTypeStatement(P);
  2166. AssertNotNull('Have type definition',D.NewType);
  2167. AssertEquals('Char type',sdtChar,D.NewType.DataType);
  2168. AssertEquals('Char type of len 10',10,D.NewType.Len);
  2169. end;
  2170. procedure TTestDomainParser.TestAlterDomainNewTypeError1;
  2171. begin
  2172. FErrSource:='ALTER DOMAIN A TYPE INT NOT NULL';
  2173. AssertException(ESQLParser,@TestParseError);
  2174. end;
  2175. procedure TTestDomainParser.TestAlterDomainNewTypeError2;
  2176. begin
  2177. FErrSource:='ALTER DOMAIN A TYPE INT DEFAULT 1';
  2178. AssertException(ESQLParser,@TestParseError);
  2179. end;
  2180. procedure TTestDomainParser.TestAlterDomainDropCheckError;
  2181. begin
  2182. FErrSource:='ALTER DOMAIN A DROP CHECK';
  2183. AssertException(ESQLParser,@TestParseError);
  2184. end;
  2185. { TTestExceptionParser }
  2186. procedure TTestExceptionParser.TestException;
  2187. Var
  2188. P : TSQLCreateOrAlterStatement;
  2189. E : TSQLCreateExceptionStatement;
  2190. begin
  2191. P:=TestCreateStatement('CREATE EXCEPTION A ''A message''','A',TSQLCreateExceptionStatement);
  2192. E:=TSQLCreateExceptionStatement(P);
  2193. AssertNotNull('Have message',E.ExceptionMessage);
  2194. AssertEquals('Message','A message',E.ExceptionMessage.Value)
  2195. end;
  2196. procedure TTestExceptionParser.TestAlterException;
  2197. Var
  2198. P : TSQLCreateOrAlterStatement;
  2199. E : TSQLCreateExceptionStatement;
  2200. begin
  2201. P:=TestCreateStatement('ALTER EXCEPTION A ''A massage''','A',TSQLAlterExceptionStatement);
  2202. E:=TSQLCreateExceptionStatement(P);
  2203. AssertNotNull('Have message',E.ExceptionMessage);
  2204. AssertEquals('Message','A massage',E.ExceptionMessage.Value)
  2205. end;
  2206. procedure TTestExceptionParser.TestExceptionError1;
  2207. begin
  2208. FErrSource:='CREATE EXCEPTION NOT';
  2209. ASsertException(ESQLParser,@TestParseError);
  2210. end;
  2211. procedure TTestExceptionParser.TestExceptionError2;
  2212. begin
  2213. FErrSource:='CREATE EXCEPTION A NOT';
  2214. ASsertException(ESQLParser,@TestParseError);
  2215. end;
  2216. { TTestRoleParser }
  2217. procedure TTestRoleParser.TestCreateRole;
  2218. begin
  2219. TestCreateStatement('CREATE ROLE A','A',TSQLCreateROLEStatement);
  2220. end;
  2221. procedure TTestRoleParser.TestAlterRole;
  2222. begin
  2223. FErrSource:='ALTER ROLE A';
  2224. ASsertException(ESQLParser,@TestParseError);
  2225. end;
  2226. { TTestIndexParser }
  2227. procedure TTestIndexParser.TestAlterindexActive;
  2228. Var
  2229. A : TSQLAlterIndexStatement;
  2230. begin
  2231. A:=TSQLAlterIndexStatement(TestCreateStatement('ALTER INDEX A ACTIVE','A',TSQLAlterIndexStatement));
  2232. AssertEquals('Active',False,A.Inactive);
  2233. end;
  2234. procedure TTestIndexParser.TestAlterindexInactive;
  2235. Var
  2236. A : TSQLAlterIndexStatement;
  2237. begin
  2238. A:=TSQLAlterIndexStatement(TestCreateStatement('ALTER INDEX A INACTIVE','A',TSQLAlterIndexStatement));
  2239. AssertEquals('Inactive',True,A.Inactive);
  2240. end;
  2241. procedure TTestIndexParser.TestCreateIndexSimple;
  2242. Var
  2243. C : TSQLCreateIndexStatement;
  2244. begin
  2245. C:=TSQLCreateIndexStatement(TestCreateStatement('CREATE INDEX A ON B (C)','A',TSQLCreateIndexStatement));
  2246. If Not (C.Options=[]) then
  2247. Fail('Options empty');
  2248. AssertIdentifiername('Correct table name','B',C.TableName);
  2249. AssertNotNull('Have fieldlist',C.FieldNames);
  2250. AssertEquals('Number of fields',1,C.FieldNames.Count);
  2251. AssertIdentifiername('Field name','C',C.FieldNames[0]);
  2252. end;
  2253. procedure TTestIndexParser.TestIndexIndexDouble;
  2254. Var
  2255. C : TSQLCreateIndexStatement;
  2256. begin
  2257. C:=TSQLCreateIndexStatement(TestCreateStatement('CREATE INDEX A ON B (C,D)','A',TSQLCreateIndexStatement));
  2258. If Not (C.Options=[]) then
  2259. Fail('Options empty');
  2260. AssertIdentifiername('Correct table name','B',C.TableName);
  2261. AssertNotNull('Have fieldlist',C.FieldNames);
  2262. AssertEquals('Number of fields',2,C.FieldNames.Count);
  2263. AssertIdentifiername('Field name 1','C',C.FieldNames[0]);
  2264. AssertIdentifiername('Field name 2','D',C.FieldNames[1]);
  2265. end;
  2266. procedure TTestIndexParser.TestIndexError1;
  2267. begin
  2268. FErrSource:='ALTER UNIQUE INDEX A ACTIVE';
  2269. AssertException(ESQLParser,@TestParseError);
  2270. end;
  2271. procedure TTestIndexParser.TestIndexError2;
  2272. begin
  2273. FErrSource:='ALTER ASCENDING INDEX A ACTIVE';
  2274. AssertException(ESQLParser,@TestParseError);
  2275. end;
  2276. procedure TTestIndexParser.TestIndexError3;
  2277. begin
  2278. FErrSource:='ALTER DESCENDING INDEX A ACTIVE';
  2279. AssertException(ESQLParser,@TestParseError);
  2280. end;
  2281. procedure TTestIndexParser.TestIndexError4;
  2282. begin
  2283. FErrSource:='CREATE INDEX A ON B';
  2284. AssertException(ESQLParser,@TestParseError);
  2285. end;
  2286. procedure TTestIndexParser.TestIndexError5;
  2287. begin
  2288. FErrSource:='CREATE INDEX A ON B ()';
  2289. AssertException(ESQLParser,@TestParseError);
  2290. end;
  2291. procedure TTestIndexParser.TestIndexError6;
  2292. begin
  2293. FErrSource:='CREATE INDEX A ON B (A,)';
  2294. AssertException(ESQLParser,@TestParseError);
  2295. end;
  2296. procedure TTestIndexParser.TestCreateIndexUnique;
  2297. Var
  2298. C : TSQLCreateIndexStatement;
  2299. begin
  2300. C:=TSQLCreateIndexStatement(TestCreateStatement('CREATE UNIQUE INDEX A ON B (C)','A',TSQLCreateIndexStatement));
  2301. If not ([ioUnique]=C.Options) then
  2302. Fail('Not Unique index');
  2303. AssertIdentifierName('Have table name','B',C.TableName);
  2304. AssertNotNull('Have fieldlist',C.FieldNames);
  2305. AssertEquals('Number of fields',1,C.FieldNames.Count);
  2306. AssertIdentifierName('Correct field name','C',C.FieldNames[0]);
  2307. end;
  2308. procedure TTestIndexParser.TestCreateIndexUniqueAscending;
  2309. Var
  2310. C : TSQLCreateIndexStatement;
  2311. begin
  2312. C:=TSQLCreateIndexStatement(TestCreateStatement('CREATE UNIQUE ASCENDING INDEX A ON B (C)','A',TSQLCreateIndexStatement));
  2313. If not ([ioUnique,ioAscending ]=C.Options) then
  2314. Fail('Not Unique ascending index');
  2315. AssertIdentifierName('Have table name','B',C.TableName);
  2316. AssertNotNull('Have fieldlist',C.FieldNames);
  2317. AssertEquals('Number of fields',1,C.FieldNames.Count);
  2318. AssertIdentifierName('Correct field name','C',C.FieldNames[0]);
  2319. end;
  2320. procedure TTestIndexParser.TestCreateIndexUniqueDescending;
  2321. Var
  2322. C : TSQLCreateIndexStatement;
  2323. begin
  2324. C:=TSQLCreateIndexStatement(TestCreateStatement('CREATE UNIQUE DESCENDING INDEX A ON B (C)','A',TSQLCreateIndexStatement));
  2325. If not ([ioUnique,ioDescending]=C.Options) then
  2326. Fail('Not Unique descending index');
  2327. AssertIdentifierName('Have table name','B',C.TableName);
  2328. AssertNotNull('Have fieldlist',C.FieldNames);
  2329. AssertEquals('Number of fields',1,C.FieldNames.Count);
  2330. AssertIdentifierName('Correct field name','C',C.FieldNames[0]);
  2331. end;
  2332. procedure TTestIndexParser.TestCreateIndexAscending;
  2333. Var
  2334. C : TSQLCreateIndexStatement;
  2335. begin
  2336. C:=TSQLCreateIndexStatement(TestCreateStatement('CREATE ASCENDING INDEX A ON B (C)','A',TSQLCreateIndexStatement));
  2337. If not ([ioAscending]=C.Options) then
  2338. Fail('Not ascending index');
  2339. AssertIdentifierName('Have table name','B',C.TableName);
  2340. AssertNotNull('Have fieldlist',C.FieldNames);
  2341. AssertEquals('Number of fields',1,C.FieldNames.Count);
  2342. AssertIdentifierName('Correct field name','C',C.FieldNames[0]);
  2343. end;
  2344. procedure TTestIndexParser.TestCreateIndexDescending;
  2345. Var
  2346. C : TSQLCreateIndexStatement;
  2347. begin
  2348. C:=TSQLCreateIndexStatement(TestCreateStatement('CREATE DESCENDING INDEX A ON B (C)','A',TSQLCreateIndexStatement));
  2349. If not ([ioDescending] = C.Options) then
  2350. Fail('Not descending index');
  2351. AssertIdentifierName('Table name','B',C.TableName);
  2352. AssertNotNull('Have fieldlist',C.FieldNames);
  2353. AssertEquals('Number of fields',1,C.FieldNames.Count);
  2354. AssertIdentifierName('Correct field name','C',C.FieldNames[0]);
  2355. end;
  2356. { TTestTableParser }
  2357. procedure TTestTableParser.DoTestCreateReferencesField(const ASource: String;
  2358. AOnUpdate, AOnDelete: TForeignKeyAction);
  2359. Var
  2360. C : TSQLCreateTableStatement;
  2361. F : TSQLTableFieldDef;
  2362. D : TSQLForeignKeyFieldConstraint;
  2363. begin
  2364. C:=TSQLCreateTableStatement(TestCreateStatement(ASource,'A',TSQLCreateTableStatement));
  2365. AssertEquals('One field',1,C.FieldDefs.Count);
  2366. AssertEquals('No constraints',0,C.Constraints.Count);
  2367. F:=TSQLTableFieldDef(CheckClass(C.FieldDefs[0],TSQLTableFieldDef));
  2368. AssertIdentifierName('fieldname','B',F.FieldName);
  2369. AssertNotNull('Have field type',F.FieldType);
  2370. AssertEquals('Correct field type',sdtInteger,F.FieldType.DataType);
  2371. AssertEquals('Field can be NULL',false,F.FieldType.NotNull);
  2372. AssertNull('Have default',F.FieldType.DefaultValue);
  2373. AssertNotNull('Have constraint',F.FieldType.Constraint);
  2374. D:=TSQLForeignKeyFieldConstraint(CheckClass(F.FieldType.Constraint,TSQLForeignKeyFieldConstraint));
  2375. AssertNull('No constraint name',D.ConstraintName);
  2376. AssertIdentifierName('Correct table name','C',D.Definition.TableName);
  2377. AssertEquals('Correct field list count',1,D.Definition.FieldList.Count);
  2378. AssertIdentifierName('Correct field name','D',D.Definition.FieldList[0]);
  2379. AssertEquals('No on update action',AOnUpdate,D.Definition.OnUpdate);
  2380. AssertEquals('No on delete action',AOnDelete,D.Definition.OnDelete);
  2381. end;
  2382. procedure TTestTableParser.TestCreateOneSimpleField;
  2383. Var
  2384. C : TSQLCreateTableStatement;
  2385. F : TSQLTableFieldDef;
  2386. begin
  2387. C:=TSQLCreateTableStatement(TestCreateStatement('CREATE TABLE A (B INT)','A',TSQLCreateTableStatement));
  2388. AssertEquals('One field',1,C.FieldDefs.Count);
  2389. AssertEquals('No constraints',0,C.Constraints.Count);
  2390. F:=TSQLTableFieldDef(CheckClass(C.FieldDefs[0],TSQLTableFieldDef));
  2391. AssertIdentifierName('fieldname','B',F.FieldName);
  2392. AssertNotNull('Have field type',F.FieldType);
  2393. AssertEquals('Correct field type',sdtInteger,F.FieldType.DataType);
  2394. end;
  2395. procedure TTestTableParser.TestCreateTwoSimpleFields;
  2396. Var
  2397. C : TSQLCreateTableStatement;
  2398. F : TSQLTableFieldDef;
  2399. begin
  2400. C:=TSQLCreateTableStatement(TestCreateStatement('CREATE TABLE A (B INT, C CHAR(5))','A',TSQLCreateTableStatement));
  2401. AssertEquals('Two fields',2,C.FieldDefs.Count);
  2402. AssertEquals('No constraints',0,C.Constraints.Count);
  2403. F:=TSQLTableFieldDef(CheckClass(C.FieldDefs[0],TSQLTableFieldDef));
  2404. AssertIdentifierName('fieldname','B',F.FieldName);
  2405. AssertNotNull('Have field type',F.FieldType);
  2406. AssertEquals('Correct field type',sdtInteger,F.FieldType.DataType);
  2407. F:=TSQLTableFieldDef(CheckClass(C.FieldDefs[1],TSQLTableFieldDef));
  2408. AssertIdentifierName('fieldname','C',F.FieldName);
  2409. AssertNotNull('Have field type',F.FieldType);
  2410. AssertEquals('Correct field type',sdtChar,F.FieldType.DataType);
  2411. end;
  2412. procedure TTestTableParser.TestCreateOnePrimaryField;
  2413. Var
  2414. C : TSQLCreateTableStatement;
  2415. F : TSQLTableFieldDef;
  2416. P : TSQLPrimaryKeyFieldConstraint;
  2417. begin
  2418. C:=TSQLCreateTableStatement(TestCreateStatement('CREATE TABLE A (B INT PRIMARY KEY)','A',TSQLCreateTableStatement));
  2419. AssertEquals('One field',1,C.FieldDefs.Count);
  2420. AssertEquals('No constraints',0,C.Constraints.Count);
  2421. F:=TSQLTableFieldDef(CheckClass(C.FieldDefs[0],TSQLTableFieldDef));
  2422. AssertIdentifierName('fieldname','B',F.FieldName);
  2423. AssertNotNull('Have field type',F.FieldType);
  2424. AssertEquals('Correct field type',sdtInteger,F.FieldType.DataType);
  2425. AssertNotNull('Have constraint',F.FieldType.Constraint);
  2426. P:=TSQLPrimaryKeyFieldConstraint(CheckClass(F.FieldType.Constraint,TSQLPrimaryKeyFieldConstraint));
  2427. AssertNull('No constraint name',P.ConstraintName);
  2428. end;
  2429. procedure TTestTableParser.TestCreateOneNamedPrimaryField;
  2430. Var
  2431. C : TSQLCreateTableStatement;
  2432. F : TSQLTableFieldDef;
  2433. P : TSQLPrimaryKeyFieldConstraint;
  2434. begin
  2435. C:=TSQLCreateTableStatement(TestCreateStatement('CREATE TABLE A (B INT CONSTRAINT C PRIMARY KEY)','A',TSQLCreateTableStatement));
  2436. AssertEquals('One field',1,C.FieldDefs.Count);
  2437. AssertEquals('No constraints',0,C.Constraints.Count);
  2438. F:=TSQLTableFieldDef(CheckClass(C.FieldDefs[0],TSQLTableFieldDef));
  2439. AssertIdentifierName('fieldname','B',F.FieldName);
  2440. AssertNotNull('Have field type',F.FieldType);
  2441. AssertEquals('Correct field type',sdtInteger,F.FieldType.DataType);
  2442. AssertNotNull('Have constraint',F.FieldType.Constraint);
  2443. P:=TSQLPrimaryKeyFieldConstraint(CheckClass(F.FieldType.Constraint,TSQLPrimaryKeyFieldConstraint));
  2444. AssertIdentifierName('Constraint name','C',P.ConstraintName);
  2445. end;
  2446. procedure TTestTableParser.TestCreateOneUniqueField;
  2447. Var
  2448. C : TSQLCreateTableStatement;
  2449. F : TSQLTableFieldDef;
  2450. U : TSQLUniqueFieldConstraint;
  2451. begin
  2452. C:=TSQLCreateTableStatement(TestCreateStatement('CREATE TABLE A (B INT UNIQUE)','A',TSQLCreateTableStatement));
  2453. AssertEquals('One field',1,C.FieldDefs.Count);
  2454. AssertEquals('No constraints',0,C.Constraints.Count);
  2455. F:=TSQLTableFieldDef(CheckClass(C.FieldDefs[0],TSQLTableFieldDef));
  2456. AssertIdentifierName('fieldname','B',F.FieldName);
  2457. AssertNotNull('Have field type',F.FieldType);
  2458. AssertEquals('Correct field type',sdtInteger,F.FieldType.DataType);
  2459. AssertNotNull('Have constraint',F.FieldType.Constraint);
  2460. U:=TSQLUniqueFieldConstraint(CheckClass(F.FieldType.Constraint,TSQLUniqueFieldConstraint));
  2461. AssertNull('No constraint name',U.ConstraintName);
  2462. end;
  2463. procedure TTestTableParser.TestCreateOneNamedUniqueField;
  2464. Var
  2465. C : TSQLCreateTableStatement;
  2466. F : TSQLTableFieldDef;
  2467. U : TSQLUniqueFieldConstraint;
  2468. begin
  2469. C:=TSQLCreateTableStatement(TestCreateStatement('CREATE TABLE A (B INT CONSTRAINT C UNIQUE)','A',TSQLCreateTableStatement));
  2470. AssertEquals('One field',1,C.FieldDefs.Count);
  2471. AssertEquals('No constraints',0,C.Constraints.Count);
  2472. F:=TSQLTableFieldDef(CheckClass(C.FieldDefs[0],TSQLTableFieldDef));
  2473. AssertIdentifierName('fieldname','B',F.FieldName);
  2474. AssertNotNull('Have field type',F.FieldType);
  2475. AssertEquals('Correct field type',sdtInteger,F.FieldType.DataType);
  2476. AssertNotNull('Have constraint',F.FieldType.Constraint);
  2477. U:=TSQLUniqueFieldConstraint(CheckClass(F.FieldType.Constraint,TSQLUniqueFieldConstraint));
  2478. AssertIdentifierName('Constraint name','C',U.ConstraintName);
  2479. end;
  2480. procedure TTestTableParser.TestCreateNotNullPrimaryField;
  2481. Var
  2482. C : TSQLCreateTableStatement;
  2483. F : TSQLTableFieldDef;
  2484. begin
  2485. C:=TSQLCreateTableStatement(TestCreateStatement('CREATE TABLE A (B INT NOT NULL PRIMARY KEY)','A',TSQLCreateTableStatement));
  2486. AssertEquals('One field',1,C.FieldDefs.Count);
  2487. AssertEquals('No constraints',0,C.Constraints.Count);
  2488. F:=TSQLTableFieldDef(CheckClass(C.FieldDefs[0],TSQLTableFieldDef));
  2489. AssertIdentifierName('fieldname','B',F.FieldName);
  2490. AssertNotNull('Have field type',F.FieldType);
  2491. AssertEquals('Correct field type',sdtInteger,F.FieldType.DataType);
  2492. AssertEquals('Field is not NULL',true,F.FieldType.NotNull);
  2493. AssertNotNull('Have constraint',F.FieldType.Constraint);
  2494. CheckClass(F.FieldType.Constraint,TSQLPrimaryKeyFieldConstraint);
  2495. end;
  2496. procedure TTestTableParser.TestCreateNotNullDefaultPrimaryField;
  2497. Var
  2498. C : TSQLCreateTableStatement;
  2499. F : TSQLTableFieldDef;
  2500. begin
  2501. C:=TSQLCreateTableStatement(TestCreateStatement('CREATE TABLE A (B INT DEFAULT 0 NOT NULL PRIMARY KEY)','A',TSQLCreateTableStatement));
  2502. AssertEquals('One field',1,C.FieldDefs.Count);
  2503. AssertEquals('No constraints',0,C.Constraints.Count);
  2504. F:=TSQLTableFieldDef(CheckClass(C.FieldDefs[0],TSQLTableFieldDef));
  2505. AssertIdentifierName('fieldname','B',F.FieldName);
  2506. AssertNotNull('Have field type',F.FieldType);
  2507. AssertEquals('Correct field type',sdtInteger,F.FieldType.DataType);
  2508. AssertEquals('Field is not NULL',true,F.FieldType.NotNull);
  2509. AssertNotNull('Have default',F.FieldType.DefaultValue);
  2510. CheckClass(F.FieldType.DefaultValue,TSQLIntegerLiteral);
  2511. AssertNotNull('Have constraint',F.FieldType.Constraint);
  2512. CheckClass(F.FieldType.Constraint,TSQLPrimaryKeyFieldConstraint);
  2513. end;
  2514. procedure TTestTableParser.TestCreateCheckField;
  2515. Var
  2516. C : TSQLCreateTableStatement;
  2517. F : TSQLTableFieldDef;
  2518. B : TSQLBinaryExpression;
  2519. CC : TSQLCheckFieldConstraint;
  2520. begin
  2521. C:=TSQLCreateTableStatement(TestCreateStatement('CREATE TABLE A (B INT CHECK (B<>0))','A',TSQLCreateTableStatement));
  2522. AssertEquals('One field',1,C.FieldDefs.Count);
  2523. AssertEquals('No constraints',0,C.Constraints.Count);
  2524. F:=TSQLTableFieldDef(CheckClass(C.FieldDefs[0],TSQLTableFieldDef));
  2525. AssertIdentifierName('fieldname','B',F.FieldName);
  2526. AssertNotNull('Have field type',F.FieldType);
  2527. AssertEquals('Correct field type',sdtInteger,F.FieldType.DataType);
  2528. AssertNull('Have no default',F.FieldType.DefaultValue);
  2529. AssertNull('Fieldtype has no check',F.FieldType.Check);
  2530. AssertNotNull('Field has constraint check',F.FieldType.Constraint);
  2531. CC:=TSQLCheckFieldConstraint(CheckClass(F.FieldType.Constraint,TSQLCheckFieldConstraint));
  2532. AssertNull('No constraint name',CC.ConstraintName);
  2533. B:=TSQLBinaryExpression(CheckClass(CC.Expression,TSQLBinaryExpression));
  2534. AssertEquals('Unequal check',boNE,B.Operation);
  2535. end;
  2536. procedure TTestTableParser.TestCreateNamedCheckField;
  2537. Var
  2538. C : TSQLCreateTableStatement;
  2539. F : TSQLTableFieldDef;
  2540. B : TSQLBinaryExpression;
  2541. CC : TSQLCheckFieldConstraint;
  2542. begin
  2543. C:=TSQLCreateTableStatement(TestCreateStatement('CREATE TABLE A (B INT CONSTRAINT C CHECK (B<>0))','A',TSQLCreateTableStatement));
  2544. AssertEquals('One field',1,C.FieldDefs.Count);
  2545. AssertEquals('No constraints',0,C.Constraints.Count);
  2546. F:=TSQLTableFieldDef(CheckClass(C.FieldDefs[0],TSQLTableFieldDef));
  2547. AssertIdentifierName('fieldname','B',F.FieldName);
  2548. AssertNotNull('Have field type',F.FieldType);
  2549. AssertEquals('Correct field type',sdtInteger,F.FieldType.DataType);
  2550. AssertNull('Have no default',F.FieldType.DefaultValue);
  2551. AssertNull('Fieldtype has no check',F.FieldType.Check);
  2552. AssertNotNull('Field has constraint check',F.FieldType.Constraint);
  2553. CC:=TSQLCheckFieldConstraint(CheckClass(F.FieldType.Constraint,TSQLCheckFieldConstraint));
  2554. AssertidentifierName('Constraint name','C',CC.ConstraintName);
  2555. B:=TSQLBinaryExpression(CheckClass(CC.Expression,TSQLBinaryExpression));
  2556. AssertEquals('Unequal check',boNE,B.Operation);
  2557. end;
  2558. procedure TTestTableParser.TestCreateReferencesField;
  2559. begin
  2560. DoTestCreateReferencesField('CREATE TABLE A (B INT REFERENCES C(D))',fkaNone,fkaNone);
  2561. end;
  2562. procedure TTestTableParser.TestCreateReferencesOnUpdateCascadeField;
  2563. begin
  2564. DoTestCreateReferencesField('CREATE TABLE A (B INT REFERENCES C(D) ON UPDATE CASCADE)',fkaCascade,fkaNone);
  2565. end;
  2566. procedure TTestTableParser.TestCreateReferencesOnUpdateNoActionField;
  2567. begin
  2568. DoTestCreateReferencesField('CREATE TABLE A (B INT REFERENCES C(D) ON UPDATE NO ACTION)',fkaNoAction,fkaNone);
  2569. end;
  2570. procedure TTestTableParser.TestCreateReferencesOnUpdateSetDefaultField;
  2571. begin
  2572. DoTestCreateReferencesField('CREATE TABLE A (B INT REFERENCES C(D) ON UPDATE SET DEFAULT)',fkaSetDefault,fkaNone);
  2573. end;
  2574. procedure TTestTableParser.TestCreateReferencesOnUpdateSetNullField;
  2575. begin
  2576. DoTestCreateReferencesField('CREATE TABLE A (B INT REFERENCES C(D) ON UPDATE SET NULL)',fkaSetNull,fkaNone);
  2577. end;
  2578. procedure TTestTableParser.TestCreateReferencesOnDeleteCascadeField;
  2579. begin
  2580. DoTestCreateReferencesField('CREATE TABLE A (B INT REFERENCES C(D) ON DELETE CASCADE)',fkaNone,fkaCascade);
  2581. end;
  2582. procedure TTestTableParser.TestCreateReferencesOnDeleteNoActionField;
  2583. begin
  2584. DoTestCreateReferencesField('CREATE TABLE A (B INT REFERENCES C(D) ON DELETE NO ACTION)',fkaNone,fkaNoAction);
  2585. end;
  2586. procedure TTestTableParser.TestCreateReferencesOnDeleteSetDefaultField;
  2587. begin
  2588. DoTestCreateReferencesField('CREATE TABLE A (B INT REFERENCES C(D) ON DELETE SET DEFAULT)',fkaNone,fkaSetDefault);
  2589. end;
  2590. procedure TTestTableParser.TestCreateReferencesOnDeleteSetNullField;
  2591. begin
  2592. DoTestCreateReferencesField('CREATE TABLE A (B INT REFERENCES C(D) ON DELETE SET NULL)',fkaNone,fkaSetNull);
  2593. end;
  2594. procedure TTestTableParser.TestCreateReferencesOnUpdateAndDeleteSetNullField;
  2595. begin
  2596. DoTestCreateReferencesField('CREATE TABLE A (B INT REFERENCES C(D) ON UPDATE SET NULL ON DELETE SET NULL)',fkaSetNull,fkaSetNull);
  2597. end;
  2598. procedure TTestTableParser.TestCreateNamedReferencesField;
  2599. Var
  2600. C : TSQLCreateTableStatement;
  2601. F : TSQLTableFieldDef;
  2602. D : TSQLForeignKeyFieldConstraint;
  2603. begin
  2604. C:=TSQLCreateTableStatement(TestCreateStatement('CREATE TABLE A (B INT CONSTRAINT FK REFERENCES C(D))','A',TSQLCreateTableStatement));
  2605. AssertEquals('One field',1,C.FieldDefs.Count);
  2606. AssertEquals('No constraints',0,C.Constraints.Count);
  2607. F:=TSQLTableFieldDef(CheckClass(C.FieldDefs[0],TSQLTableFieldDef));
  2608. AssertIdentifierName('fieldname','B',F.FieldName);
  2609. AssertNotNull('Have field type',F.FieldType);
  2610. AssertEquals('Correct field type',sdtInteger,F.FieldType.DataType);
  2611. AssertEquals('Field can be NULL',false,F.FieldType.NotNull);
  2612. AssertNull('Have default',F.FieldType.DefaultValue);
  2613. AssertNotNull('Have constraint',F.FieldType.Constraint);
  2614. D:=TSQLForeignKeyFieldConstraint(CheckClass(F.FieldType.Constraint,TSQLForeignKeyFieldConstraint));
  2615. AssertIdentifierName('Correct constraint name','FK',D.ConstraintName);
  2616. AssertIdentifierName('Correct table name','C',D.Definition.TableName);
  2617. AssertEquals('Correct field list count',1,D.Definition.FieldList.Count);
  2618. AssertIdentifierName('Correct field name','D',D.Definition.FieldList[0]);
  2619. end;
  2620. procedure TTestTableParser.TestCreateComputedByField;
  2621. Var
  2622. C : TSQLCreateTableStatement;
  2623. F : TSQLTableFieldDef;
  2624. B : TSQLBinaryExpression;
  2625. begin
  2626. C:=TSQLCreateTableStatement(TestCreateStatement('CREATE TABLE A (B INT, C INT, D COMPUTED BY (B+C))','A',TSQLCreateTableStatement));
  2627. AssertEquals('Three fields',3,C.FieldDefs.Count);
  2628. AssertEquals('No constraints',0,C.Constraints.Count);
  2629. F:=TSQLTableFieldDef(CheckClass(C.FieldDefs[2],TSQLTableFieldDef));
  2630. AssertIdentifierName('fieldname','D',F.FieldName);
  2631. AssertNull('No field type',F.FieldType);
  2632. AssertNotNull('Have computed by expression',F.ComputedBy);
  2633. B:=TSQLBinaryExpression(CheckClass(F.ComputedBy,TSQLBinaryExpression));
  2634. AssertEquals('Add operation',boAdd,B.Operation);
  2635. CheckClass(B.Left,TSQLIdentifierExpression);
  2636. AssertIdentifierName('Correct identifier','B',TSQLIdentifierExpression(B.Left).Identifier);
  2637. CheckClass(B.Right,TSQLIdentifierExpression);
  2638. AssertIdentifierName('Correct identifier','C',TSQLIdentifierExpression(B.Right).Identifier);
  2639. end;
  2640. procedure TTestTableParser.TestCreatePrimaryKeyConstraint;
  2641. Var
  2642. C : TSQLCreateTableStatement;
  2643. F : TSQLTableFieldDef;
  2644. P: TSQLTablePrimaryKeyConstraintDef;
  2645. begin
  2646. C:=TSQLCreateTableStatement(TestCreateStatement('CREATE TABLE A (B INT, PRIMARY KEY (B))','A',TSQLCreateTableStatement));
  2647. AssertEquals('One field',1,C.FieldDefs.Count);
  2648. AssertEquals('One constraints',1,C.Constraints.Count);
  2649. F:=TSQLTableFieldDef(CheckClass(C.FieldDefs[0],TSQLTableFieldDef));
  2650. AssertIdentifierName('fieldname','B',F.FieldName);
  2651. P:=TSQLTablePrimaryKeyConstraintDef(CheckClass(C.Constraints[0],TSQLTablePrimaryKeyConstraintDef));
  2652. AssertNotNull('Fieldlist assigned',P.FieldList);
  2653. AssertNull('Constraint name empty',P.ConstraintName);
  2654. AssertEquals('One field in primary key',1,P.FieldList.Count);
  2655. AssertIdentifierName('fieldname','B',P.FieldList[0]);
  2656. end;
  2657. procedure TTestTableParser.TestCreateNamedPrimaryKeyConstraint;
  2658. Var
  2659. C : TSQLCreateTableStatement;
  2660. F : TSQLTableFieldDef;
  2661. P: TSQLTablePrimaryKeyConstraintDef;
  2662. begin
  2663. C:=TSQLCreateTableStatement(TestCreateStatement('CREATE TABLE A (B INT, CONSTRAINT A_PK PRIMARY KEY (B))','A',TSQLCreateTableStatement));
  2664. AssertEquals('One field',1,C.FieldDefs.Count);
  2665. AssertEquals('One constraints',1,C.Constraints.Count);
  2666. F:=TSQLTableFieldDef(CheckClass(C.FieldDefs[0],TSQLTableFieldDef));
  2667. AssertIdentifierName('fieldname','B',F.FieldName);
  2668. P:=TSQLTablePrimaryKeyConstraintDef(CheckClass(C.Constraints[0],TSQLTablePrimaryKeyConstraintDef));
  2669. AssertNotNull('Fieldlist assigned',P.FieldList);
  2670. AssertIdentifierName('fieldname','A_PK',P.ConstraintName);
  2671. AssertEquals('One field in primary key',1,P.FieldList.Count);
  2672. AssertIdentifierName('fieldname','B',P.FieldList[0]);
  2673. end;
  2674. procedure TTestTableParser.TestCreateForeignKeyConstraint;
  2675. Var
  2676. C : TSQLCreateTableStatement;
  2677. F : TSQLTableFieldDef;
  2678. P: TSQLTableForeignKeyConstraintDef;
  2679. begin
  2680. C:=TSQLCreateTableStatement(TestCreateStatement('CREATE TABLE A (B INT, FOREIGN KEY (B) REFERENCES C(D))','A',TSQLCreateTableStatement));
  2681. AssertEquals('One field',1,C.FieldDefs.Count);
  2682. AssertEquals('One constraints',1,C.Constraints.Count);
  2683. F:=TSQLTableFieldDef(CheckClass(C.FieldDefs[0],TSQLTableFieldDef));
  2684. AssertIdentifierName('fieldname','B',F.FieldName);
  2685. P:=TSQLTableForeignKeyConstraintDef(CheckClass(C.Constraints[0],TSQLTableForeignKeyConstraintDef));
  2686. AssertNotNull('Fieldlist assigned',P.FieldList);
  2687. AssertNull('Constraint name',P.ConstraintName);
  2688. AssertEquals('One field in foreign key',1,P.FieldList.Count);
  2689. AssertIdentifierName('fieldname','B',P.FieldList[0]);
  2690. AssertIdentifierName('Target table name','C',P.Definition.TableName);
  2691. AssertEquals('One field in primary key target',1,P.Definition.FieldList.Count);
  2692. AssertIdentifierName('target fieldname','D',P.Definition.FieldList[0]);
  2693. end;
  2694. procedure TTestTableParser.TestCreateNamedForeignKeyConstraint;
  2695. Var
  2696. C : TSQLCreateTableStatement;
  2697. F : TSQLTableFieldDef;
  2698. P: TSQLTableForeignKeyConstraintDef;
  2699. begin
  2700. C:=TSQLCreateTableStatement(TestCreateStatement('CREATE TABLE A (B INT, CONSTRAINT A_FK FOREIGN KEY (B) REFERENCES C(D))','A',TSQLCreateTableStatement));
  2701. AssertEquals('One field',1,C.FieldDefs.Count);
  2702. AssertEquals('One constraints',1,C.Constraints.Count);
  2703. F:=TSQLTableFieldDef(CheckClass(C.FieldDefs[0],TSQLTableFieldDef));
  2704. AssertIdentifierName('fieldname','B',F.FieldName);
  2705. P:=TSQLTableForeignKeyConstraintDef(CheckClass(C.Constraints[0],TSQLTableForeignKeyConstraintDef));
  2706. AssertNotNull('Fieldlist assigned',P.FieldList);
  2707. AssertIdentifierName('fieldname','A_FK',P.ConstraintName);
  2708. AssertEquals('One field in foreign key',1,P.FieldList.Count);
  2709. AssertIdentifierName('fieldname','B',P.FieldList[0]);
  2710. AssertIdentifierName('Target table name','C',P.Definition.TableName);
  2711. AssertEquals('One field in primary key target',1,P.Definition.FieldList.Count);
  2712. AssertIdentifierName('target fieldname','D',P.Definition.FieldList[0]);
  2713. end;
  2714. procedure TTestTableParser.TestCreateUniqueConstraint;
  2715. Var
  2716. C : TSQLCreateTableStatement;
  2717. F : TSQLTableFieldDef;
  2718. P: TSQLTableUniqueConstraintDef;
  2719. begin
  2720. C:=TSQLCreateTableStatement(TestCreateStatement('CREATE TABLE A (B INT, UNIQUE (B))','A',TSQLCreateTableStatement));
  2721. AssertEquals('One field',1,C.FieldDefs.Count);
  2722. AssertEquals('One constraints',1,C.Constraints.Count);
  2723. F:=TSQLTableFieldDef(CheckClass(C.FieldDefs[0],TSQLTableFieldDef));
  2724. AssertIdentifierName('fieldname','B',F.FieldName);
  2725. P:=TSQLTableUniqueConstraintDef(CheckClass(C.Constraints[0],TSQLTableUniqueConstraintDef));
  2726. AssertNotNull('Fieldlist assigned',P.FieldList);
  2727. AssertNull('Constraint name empty',P.ConstraintName);
  2728. AssertEquals('One field in primary key',1,P.FieldList.Count);
  2729. AssertIdentifierName('Name is correct','B',P.FieldList[0]);
  2730. end;
  2731. procedure TTestTableParser.TestCreateNamedUniqueConstraint;
  2732. Var
  2733. C : TSQLCreateTableStatement;
  2734. F : TSQLTableFieldDef;
  2735. P: TSQLTableUniqueConstraintDef;
  2736. begin
  2737. C:=TSQLCreateTableStatement(TestCreateStatement('CREATE TABLE A (B INT, CONSTRAINT U_A UNIQUE (B))','A',TSQLCreateTableStatement));
  2738. AssertEquals('One field',1,C.FieldDefs.Count);
  2739. AssertEquals('One constraints',1,C.Constraints.Count);
  2740. F:=TSQLTableFieldDef(CheckClass(C.FieldDefs[0],TSQLTableFieldDef));
  2741. AssertIdentifierName('fieldname','B',F.FieldName);
  2742. P:=TSQLTableUniqueConstraintDef(CheckClass(C.Constraints[0],TSQLTableUniqueConstraintDef));
  2743. AssertNotNull('Fieldlist assigned',P.FieldList);
  2744. AssertIdentifierName('fieldname','U_A',P.ConstraintName);
  2745. AssertEquals('One field in primary key',1,P.FieldList.Count);
  2746. AssertIdentifierName('Name is correct','B',P.FieldList[0]);
  2747. end;
  2748. procedure TTestTableParser.TestCreateCheckConstraint;
  2749. Var
  2750. C : TSQLCreateTableStatement;
  2751. F : TSQLTableFieldDef;
  2752. B : TSQLBinaryExpression;
  2753. P: TSQLTableCheckConstraintDef;
  2754. begin
  2755. C:=TSQLCreateTableStatement(TestCreateStatement('CREATE TABLE A (B INT, CHECK (B<>0))','A',TSQLCreateTableStatement));
  2756. AssertEquals('One field',1,C.FieldDefs.Count);
  2757. AssertEquals('One constraints',1,C.Constraints.Count);
  2758. F:=TSQLTableFieldDef(CheckClass(C.FieldDefs[0],TSQLTableFieldDef));
  2759. AssertIdentifierName('fieldname','B',F.FieldName);
  2760. P:=TSQLTableCheckConstraintDef(CheckClass(C.Constraints[0],TSQLTableCheckConstraintDef));
  2761. AssertNull('Constraint name empty',P.ConstraintName);
  2762. AssertNotNull('Check expression assigned',P.Check);
  2763. B:=TSQLBinaryExpression(CheckClass(P.Check,TSQLBinaryExpression));
  2764. AssertEquals('Unequal',boNE,B.Operation);
  2765. end;
  2766. procedure TTestTableParser.TestCreateNamedCheckConstraint;
  2767. Var
  2768. C : TSQLCreateTableStatement;
  2769. F : TSQLTableFieldDef;
  2770. B : TSQLBinaryExpression;
  2771. P: TSQLTableCheckConstraintDef;
  2772. begin
  2773. C:=TSQLCreateTableStatement(TestCreateStatement('CREATE TABLE A (B INT, CONSTRAINT C_A CHECK (B<>0))','A',TSQLCreateTableStatement));
  2774. AssertEquals('One field',1,C.FieldDefs.Count);
  2775. AssertEquals('One constraints',1,C.Constraints.Count);
  2776. F:=TSQLTableFieldDef(CheckClass(C.FieldDefs[0],TSQLTableFieldDef));
  2777. AssertIdentifierName('fieldname','B',F.FieldName);
  2778. P:=TSQLTableCheckConstraintDef(CheckClass(C.Constraints[0],TSQLTableCheckConstraintDef));
  2779. AssertIdentifierName('Constainrname','C_A',P.ConstraintName);
  2780. AssertNotNull('Check expression assigned',P.Check);
  2781. B:=TSQLBinaryExpression(CheckClass(P.Check,TSQLBinaryExpression));
  2782. AssertEquals('Not equal operation',boNE,B.Operation);
  2783. end;
  2784. procedure TTestTableParser.TestAlterDropField;
  2785. Var
  2786. A : TSQLAlterTableStatement;
  2787. D : TSQLDropTableFieldOperation;
  2788. begin
  2789. A:=TSQLAlterTableStatement(TestCreateStatement('ALTER TABLE A DROP B','A',TSQLAlterTableStatement));
  2790. AssertEquals('One operation',1,A.Operations.Count);
  2791. D:=TSQLDropTableFieldOperation(CheckClass(A.Operations[0],TSQLDropTableFieldOperation));
  2792. AssertidentifierName('Drop field name','B',D.ObjectName);
  2793. end;
  2794. procedure TTestTableParser.TestAlterDropFields;
  2795. Var
  2796. A : TSQLAlterTableStatement;
  2797. D : TSQLDropTableFieldOperation;
  2798. begin
  2799. A:=TSQLAlterTableStatement(TestCreateStatement('ALTER TABLE A DROP B, DROP C','A',TSQLAlterTableStatement));
  2800. AssertEquals('Two operations',2,A.Operations.Count);
  2801. D:=TSQLDropTableFieldOperation(CheckClass(A.Operations[0],TSQLDropTableFieldOperation));
  2802. AssertidentifierName('Drop field name','B',D.ObjectName);
  2803. D:=TSQLDropTableFieldOperation(CheckClass(A.Operations[1],TSQLDropTableFieldOperation));
  2804. AssertidentifierName('Drop field name','C',D.ObjectName);
  2805. end;
  2806. procedure TTestTableParser.TestAlterDropConstraint;
  2807. Var
  2808. A : TSQLAlterTableStatement;
  2809. D : TSQLDropTableConstraintOperation;
  2810. begin
  2811. A:=TSQLAlterTableStatement(TestCreateStatement('ALTER TABLE A DROP CONSTRAINT B','A',TSQLAlterTableStatement));
  2812. AssertEquals('One operation',1,A.Operations.Count);
  2813. D:=TSQLDropTableConstraintOperation(CheckClass(A.Operations[0],TSQLDropTableConstraintOperation));
  2814. AssertidentifierName('Drop field name','B',D.ObjectName);
  2815. end;
  2816. procedure TTestTableParser.TestAlterDropConstraints;
  2817. Var
  2818. A : TSQLAlterTableStatement;
  2819. D : TSQLDropTableConstraintOperation;
  2820. begin
  2821. A:=TSQLAlterTableStatement(TestCreateStatement('ALTER TABLE A DROP CONSTRAINT B, DROP CONSTRAINT C','A',TSQLAlterTableStatement));
  2822. AssertEquals('Two operations',2,A.Operations.Count);
  2823. D:=TSQLDropTableConstraintOperation(CheckClass(A.Operations[0],TSQLDropTableConstraintOperation));
  2824. AssertidentifierName('Drop Constraint name','B',D.ObjectName);
  2825. D:=TSQLDropTableConstraintOperation(CheckClass(A.Operations[1],TSQLDropTableConstraintOperation));
  2826. AssertidentifierName('Drop field name','C',D.ObjectName);
  2827. end;
  2828. procedure TTestTableParser.TestAlterRenameField;
  2829. Var
  2830. A : TSQLAlterTableStatement;
  2831. R : TSQLAlterTableFieldNameOperation;
  2832. begin
  2833. A:=TSQLAlterTableStatement(TestCreateStatement('ALTER TABLE A ALTER B TO C','A',TSQLAlterTableStatement));
  2834. AssertEquals('One operation',1,A.Operations.Count);
  2835. R:=TSQLAlterTableFieldNameOperation(CheckClass(A.Operations[0],TSQLAlterTableFieldNameOperation));
  2836. AssertidentifierName('Old field name','B',R.ObjectName);
  2837. AssertidentifierName('New field name','C',R.NewName);
  2838. end;
  2839. procedure TTestTableParser.TestAlterRenameColumnField;
  2840. Var
  2841. A : TSQLAlterTableStatement;
  2842. R : TSQLAlterTableFieldNameOperation;
  2843. begin
  2844. A:=TSQLAlterTableStatement(TestCreateStatement('ALTER TABLE A ALTER COLUMN B TO C','A',TSQLAlterTableStatement));
  2845. AssertEquals('One operation',1,A.Operations.Count);
  2846. R:=TSQLAlterTableFieldNameOperation(CheckClass(A.Operations[0],TSQLAlterTableFieldNameOperation));
  2847. AssertidentifierName('Old field name','B',R.ObjectName);
  2848. AssertidentifierName('New field name','C',R.NewName);
  2849. end;
  2850. procedure TTestTableParser.TestAlterFieldType;
  2851. Var
  2852. A : TSQLAlterTableStatement;
  2853. R : TSQLAlterTableFieldTypeOperation;
  2854. begin
  2855. A:=TSQLAlterTableStatement(TestCreateStatement('ALTER TABLE A ALTER COLUMN B TYPE INT','A',TSQLAlterTableStatement));
  2856. AssertEquals('One operation',1,A.Operations.Count);
  2857. R:=TSQLAlterTableFieldTypeOperation(CheckClass(A.Operations[0],TSQLAlterTableFieldTypeOperation));
  2858. AssertidentifierName('Old field name','B',R.ObjectName);
  2859. AssertNotNull('Have field type',R.NewType);
  2860. Checkclass(R.NewType,TSQLTypeDefinition);
  2861. AssertEquals('Correct data type',sdtInteger,R.NewType.DataType);
  2862. end;
  2863. procedure TTestTableParser.TestAlterFieldPosition;
  2864. Var
  2865. A : TSQLAlterTableStatement;
  2866. R : TSQLAlterTableFieldPositionOperation;
  2867. begin
  2868. A:=TSQLAlterTableStatement(TestCreateStatement('ALTER TABLE A ALTER COLUMN B POSITION 3','A',TSQLAlterTableStatement));
  2869. AssertEquals('One operation',1,A.Operations.Count);
  2870. R:=TSQLAlterTableFieldPositionOperation(CheckClass(A.Operations[0],TSQLAlterTableFieldPositionOperation));
  2871. AssertidentifierName('Old field name','B',R.ObjectName);
  2872. AssertEquals('Correct position',3,R.NewPosition);
  2873. end;
  2874. procedure TTestTableParser.TestAlterAddField;
  2875. Var
  2876. A : TSQLAlterTableStatement;
  2877. F : TSQLAlterTableAddFieldOperation;
  2878. D : TSQLTableFieldDef;
  2879. begin
  2880. A:=TSQLAlterTableStatement(TestCreateStatement('ALTER TABLE A ADD B INT','A',TSQLAlterTableStatement));
  2881. AssertEquals('One operation',1,A.Operations.Count);
  2882. F:=TSQLAlterTableAddFieldOperation(CheckClass(A.Operations[0],TSQLAlterTableAddFieldOperation));
  2883. AssertNotNull('Have element',F.Element);
  2884. D:=TSQLTableFieldDef(CheckClass(F.Element,TSQLTableFieldDef));
  2885. AssertIdentifierName('New field name','B',D.FieldName);
  2886. AssertNotNull('Have fielddef',D.FieldType);
  2887. AssertEquals('Correct field type',sdtINteger,D.FieldType.DataType);
  2888. end;
  2889. procedure TTestTableParser.TestAlterAddFields;
  2890. Var
  2891. A : TSQLAlterTableStatement;
  2892. F : TSQLAlterTableAddFieldOperation;
  2893. D : TSQLTableFieldDef;
  2894. begin
  2895. A:=TSQLAlterTableStatement(TestCreateStatement('ALTER TABLE A ADD B INT, ADD C CHAR(50)','A',TSQLAlterTableStatement));
  2896. AssertEquals('Two operations',2,A.Operations.Count);
  2897. F:=TSQLAlterTableAddFieldOperation(CheckClass(A.Operations[0],TSQLAlterTableAddFieldOperation));
  2898. AssertNotNull('Have element',F.Element);
  2899. D:=TSQLTableFieldDef(CheckClass(F.Element,TSQLTableFieldDef));
  2900. AssertIdentifierName('New field name','B',D.FieldName);
  2901. AssertNotNull('Have fielddef',D.FieldType);
  2902. AssertEquals('Correct field type',sdtINteger,D.FieldType.DataType);
  2903. F:=TSQLAlterTableAddFieldOperation(CheckClass(A.Operations[1],TSQLAlterTableAddFieldOperation));
  2904. AssertNotNull('Have element',F.Element);
  2905. D:=TSQLTableFieldDef(CheckClass(F.Element,TSQLTableFieldDef));
  2906. AssertIdentifierName('New field name','C',D.FieldName);
  2907. AssertNotNull('Have fielddef',D.FieldType);
  2908. AssertEquals('Correct field type',sdtChar,D.FieldType.DataType);
  2909. AssertEquals('Correct field lengthe',50,D.FieldType.Len);
  2910. end;
  2911. procedure TTestTableParser.TestAlterAddPrimarykey;
  2912. Var
  2913. A : TSQLAlterTableStatement;
  2914. F : TSQLAlterTableAddConstraintOperation;
  2915. D : TSQLTablePrimaryKeyConstraintDef;
  2916. begin
  2917. A:=TSQLAlterTableStatement(TestCreateStatement('ALTER TABLE A ADD PRIMARY KEY (B)','A',TSQLAlterTableStatement));
  2918. AssertEquals('One operation',1,A.Operations.Count);
  2919. F:=TSQLAlterTableAddConstraintOperation(CheckClass(A.Operations[0],TSQLAlterTableAddConstraintOperation));
  2920. AssertNotNull('Have element',F.Element);
  2921. D:=TSQLTablePrimaryKeyConstraintDef(CheckClass(F.Element,TSQLTablePrimaryKeyConstraintDef));
  2922. AssertNull('No constraint name',D.ConstraintName);
  2923. AssertEquals('Have 1 field',1,D.FieldList.Count);
  2924. AssertIdentifierName('fieldname','B',D.FieldList[0]);
  2925. end;
  2926. procedure TTestTableParser.TestAlterAddNamedPrimarykey;
  2927. Var
  2928. A : TSQLAlterTableStatement;
  2929. F : TSQLAlterTableAddConstraintOperation;
  2930. D : TSQLTablePrimaryKeyConstraintDef;
  2931. begin
  2932. A:=TSQLAlterTableStatement(TestCreateStatement('ALTER TABLE A ADD CONSTRAINT U_K PRIMARY KEY (B)','A',TSQLAlterTableStatement));
  2933. AssertEquals('One operation',1,A.Operations.Count);
  2934. F:=TSQLAlterTableAddConstraintOperation(CheckClass(A.Operations[0],TSQLAlterTableAddConstraintOperation));
  2935. AssertNotNull('Have element',F.Element);
  2936. D:=TSQLTablePrimaryKeyConstraintDef(CheckClass(F.Element,TSQLTablePrimaryKeyConstraintDef));
  2937. AssertIdentifierName('No constraint name','U_K',D.ConstraintName);
  2938. AssertEquals('Have 1 field',1,D.FieldList.Count);
  2939. AssertIdentifierName('fieldname','B',D.FieldList[0]);
  2940. end;
  2941. procedure TTestTableParser.TestAlterAddCheckConstraint;
  2942. Var
  2943. A : TSQLAlterTableStatement;
  2944. F : TSQLAlterTableAddConstraintOperation;
  2945. D : TSQLTableCheckConstraintDef;
  2946. begin
  2947. A:=TSQLAlterTableStatement(TestCreateStatement('ALTER TABLE A ADD CHECK (B<>0)','A',TSQLAlterTableStatement));
  2948. AssertEquals('One operation',1,A.Operations.Count);
  2949. F:=TSQLAlterTableAddConstraintOperation(CheckClass(A.Operations[0],TSQLAlterTableAddConstraintOperation));
  2950. AssertNotNull('Have element',F.Element);
  2951. D:=TSQLTableCheckConstraintDef(CheckClass(F.Element,TSQLTableCheckConstraintDef));
  2952. AssertNull('Constaintname',D.ConstraintName);
  2953. AssertNotNull('Check expression assigned',D.Check);
  2954. CheckClass(D.Check,TSQLBinaryExpression);
  2955. end;
  2956. procedure TTestTableParser.TestAlterAddNamedCheckConstraint;
  2957. Var
  2958. A : TSQLAlterTableStatement;
  2959. F : TSQLAlterTableAddConstraintOperation;
  2960. D : TSQLTableCheckConstraintDef;
  2961. begin
  2962. A:=TSQLAlterTableStatement(TestCreateStatement('ALTER TABLE A ADD CONSTRAINT C_A CHECK (B<>0)','A',TSQLAlterTableStatement));
  2963. AssertEquals('One operation',1,A.Operations.Count);
  2964. F:=TSQLAlterTableAddConstraintOperation(CheckClass(A.Operations[0],TSQLAlterTableAddConstraintOperation));
  2965. AssertNotNull('Have element',F.Element);
  2966. D:=TSQLTableCheckConstraintDef(CheckClass(F.Element,TSQLTableCheckConstraintDef));
  2967. AssertIdentifierName('Constaintname','C_A',D.ConstraintName);
  2968. AssertNotNull('Check expression assigned',D.Check);
  2969. CheckClass(D.Check,TSQLBinaryExpression);
  2970. end;
  2971. procedure TTestTableParser.TestAlterAddForeignkey;
  2972. Var
  2973. A : TSQLAlterTableStatement;
  2974. F : TSQLAlterTableAddConstraintOperation;
  2975. D : TSQLTableForeignKeyConstraintDef;
  2976. begin
  2977. A:=TSQLAlterTableStatement(TestCreateStatement('ALTER TABLE A ADD FOREIGN KEY (B) REFERENCES C(D)','A',TSQLAlterTableStatement));
  2978. AssertEquals('One operation',1,A.Operations.Count);
  2979. F:=TSQLAlterTableAddConstraintOperation(CheckClass(A.Operations[0],TSQLAlterTableAddConstraintOperation));
  2980. AssertNotNull('Have element',F.Element);
  2981. D:=TSQLTableForeignKeyConstraintDef(CheckClass(F.Element,TSQLTableForeignKeyConstraintDef));
  2982. AssertNull('No constraint name',D.ConstraintName);
  2983. AssertEquals('Have 1 field',1,D.FieldList.Count);
  2984. AssertIdentifierName('fieldname','B',D.FieldList[0]);
  2985. AssertIdentifierName('Target table name','C',D.Definition.TableName);
  2986. AssertEquals('One field in primary key target',1,D.Definition.FieldList.Count);
  2987. AssertIdentifierName('target fieldname','D',D.Definition.FieldList[0]);
  2988. end;
  2989. procedure TTestTableParser.TestAlterAddNamedForeignkey;
  2990. Var
  2991. A : TSQLAlterTableStatement;
  2992. F : TSQLAlterTableAddConstraintOperation;
  2993. D : TSQLTableForeignKeyConstraintDef;
  2994. begin
  2995. A:=TSQLAlterTableStatement(TestCreateStatement('ALTER TABLE A ADD CONSTRAINT F_A FOREIGN KEY (B) REFERENCES C(D)','A',TSQLAlterTableStatement));
  2996. AssertEquals('One operation',1,A.Operations.Count);
  2997. F:=TSQLAlterTableAddConstraintOperation(CheckClass(A.Operations[0],TSQLAlterTableAddConstraintOperation));
  2998. AssertNotNull('Have element',F.Element);
  2999. D:=TSQLTableForeignKeyConstraintDef(CheckClass(F.Element,TSQLTableForeignKeyConstraintDef));
  3000. AssertIdentifierName('constraint name','F_A',D.ConstraintName);
  3001. AssertEquals('Have 1 field',1,D.FieldList.Count);
  3002. AssertIdentifierName('fieldname','B',D.FieldList[0]);
  3003. AssertIdentifierName('Target table name','C',D.Definition.TableName);
  3004. AssertEquals('One field in primary key target',1,D.Definition.FieldList.Count);
  3005. AssertIdentifierName('target fieldname','D',D.Definition.FieldList[0]);
  3006. end;
  3007. { TTestDeleteParser }
  3008. function TTestDeleteParser.TestDelete(const ASource,ATable: String
  3009. ): TSQLDeleteStatement;
  3010. begin
  3011. CreateParser(ASource);
  3012. FToFree:=Parser.Parse;
  3013. Result:=TSQLDeleteStatement(CheckClass(FToFree,TSQLDeleteStatement));
  3014. AssertIdentifierName('Correct table name',ATable,Result.TableName);
  3015. AssertEquals('End of stream reached',tsqlEOF,Parser.CurrentToken);
  3016. end;
  3017. procedure TTestDeleteParser.TestSimpleDelete;
  3018. Var
  3019. D : TSQLDeleteStatement;
  3020. begin
  3021. D:=TestDelete('DELETE FROM A','A');
  3022. AssertNull('No where',D.WhereClause);
  3023. end;
  3024. procedure TTestDeleteParser.TestSimpleDeleteAlias;
  3025. Var
  3026. D : TSQLDeleteStatement;
  3027. begin
  3028. D:=TestDelete('DELETE FROM A B','A');
  3029. AssertIdentifierName('Alias name','B',D.AliasName);
  3030. AssertNull('No where',D.WhereClause);
  3031. end;
  3032. procedure TTestDeleteParser.TestDeleteWhereNull;
  3033. Var
  3034. D : TSQLDeleteStatement;
  3035. B : TSQLBinaryExpression;
  3036. I : TSQLIdentifierExpression;
  3037. L : TSQLLiteralExpression;
  3038. begin
  3039. D:=TestDelete('DELETE FROM A WHERE B IS NULL','A');
  3040. AssertNotNull('No where',D.WhereClause);
  3041. B:=TSQLBinaryExpression(CheckClass(D.WhereClause,TSQLBinaryExpression));
  3042. AssertEquals('Is null operation',boIs,B.Operation);
  3043. I:=TSQLIdentifierExpression(CheckClass(B.Left,TSQLIdentifierExpression));
  3044. AssertIdentifierName('Correct field name','B',I.Identifier);
  3045. L:=TSQLLiteralExpression(CheckClass(B.Right,TSQLLiteralExpression));
  3046. CheckClass(L.Literal,TSQLNullLiteral);
  3047. end;
  3048. { TTestUpdateParser }
  3049. function TTestUpdateParser.TestUpdate(const ASource, ATable: String
  3050. ): TSQLUpdateStatement;
  3051. begin
  3052. CreateParser(ASource);
  3053. FToFree:=Parser.Parse;
  3054. Result:=TSQLUpdateStatement(CheckClass(FToFree,TSQLUpdateStatement));
  3055. AssertIdentifierName('Correct table name',ATable,Result.TableName);
  3056. AssertEquals('End of stream reached',tsqlEOF,Parser.CurrentToken);
  3057. end;
  3058. procedure TTestUpdateParser.TestUpdateOneField;
  3059. Var
  3060. U : TSQLUpdateStatement;
  3061. P : TSQLUpdatePair;
  3062. E : TSQLLiteralExpression;
  3063. I : TSQLIntegerLiteral;
  3064. begin
  3065. U:=TestUpdate('UPDATE A SET B=1','A');
  3066. AssertEquals('One field updated',1,U.Values.Count);
  3067. P:=TSQLUpdatePair(CheckClass(U.Values[0],TSQLUpdatePair));
  3068. AssertIdentifierName('Correct field name','B',P.FieldName);
  3069. E:=TSQLLiteralExpression(CheckClass(P.Value,TSQLLiteralExpression));
  3070. I:=TSQLIntegerLiteral(CheckClass(E.Literal,TSQLIntegerLiteral));
  3071. AssertEquals('Value 1',1,I.Value);
  3072. AssertNull('No where clause',U.WhereClause);
  3073. end;
  3074. procedure TTestUpdateParser.TestUpdateOneFieldFull;
  3075. Var
  3076. U : TSQLUpdateStatement;
  3077. P : TSQLUpdatePair;
  3078. E : TSQLLiteralExpression;
  3079. I : TSQLIntegerLiteral;
  3080. begin
  3081. U:=TestUpdate('UPDATE A SET A.B=1','A');
  3082. AssertEquals('One field updated',1,U.Values.Count);
  3083. P:=TSQLUpdatePair(CheckClass(U.Values[0],TSQLUpdatePair));
  3084. AssertIdentifierName('Correct field name','A.B',P.FieldName);
  3085. E:=TSQLLiteralExpression(CheckClass(P.Value,TSQLLiteralExpression));
  3086. I:=TSQLIntegerLiteral(CheckClass(E.Literal,TSQLIntegerLiteral));
  3087. AssertEquals('Value 1',1,I.Value);
  3088. AssertNull('No where clause',U.WhereClause);
  3089. end;
  3090. procedure TTestUpdateParser.TestUpdateTwoFields;
  3091. Var
  3092. U : TSQLUpdateStatement;
  3093. P : TSQLUpdatePair;
  3094. E : TSQLLiteralExpression;
  3095. I : TSQLIntegerLiteral;
  3096. begin
  3097. U:=TestUpdate('UPDATE A SET B=1, C=2','A');
  3098. AssertEquals('One field updated',2,U.Values.Count);
  3099. P:=TSQLUpdatePair(CheckClass(U.Values[0],TSQLUpdatePair));
  3100. AssertIdentifierName('Correct field name','B',P.FieldName);
  3101. E:=TSQLLiteralExpression(CheckClass(P.Value,TSQLLiteralExpression));
  3102. I:=TSQLIntegerLiteral(CheckClass(E.Literal,TSQLIntegerLiteral));
  3103. AssertEquals('Value 1',1,I.Value);
  3104. P:=TSQLUpdatePair(CheckClass(U.Values[1],TSQLUpdatePair));
  3105. AssertIdentifierName('Correct field name','C',P.FieldName);
  3106. E:=TSQLLiteralExpression(CheckClass(P.Value,TSQLLiteralExpression));
  3107. I:=TSQLIntegerLiteral(CheckClass(E.Literal,TSQLIntegerLiteral));
  3108. AssertEquals('Value 2',2,I.Value);
  3109. AssertNull('No where clause',U.WhereClause);
  3110. end;
  3111. procedure TTestUpdateParser.TestUpdateOneFieldWhereIsNull;
  3112. Var
  3113. U : TSQLUpdateStatement;
  3114. P : TSQLUpdatePair;
  3115. E : TSQLLiteralExpression;
  3116. I : TSQLIntegerLiteral;
  3117. B : TSQLBinaryExpression;
  3118. IE : TSQLIdentifierExpression;
  3119. L : TSQLLiteralExpression;
  3120. begin
  3121. U:=TestUpdate('UPDATE A SET B=1 WHERE B IS NULL','A');
  3122. AssertEquals('One field updated',1,U.Values.Count);
  3123. P:=TSQLUpdatePair(CheckClass(U.Values[0],TSQLUpdatePair));
  3124. AssertIdentifierName('Correct field name','B',P.FieldName);
  3125. E:=TSQLLiteralExpression(CheckClass(P.Value,TSQLLiteralExpression));
  3126. I:=TSQLIntegerLiteral(CheckClass(E.Literal,TSQLIntegerLiteral));
  3127. AssertEquals('Value 1',1,I.Value);
  3128. AssertNotNull('where clause',U.WhereClause);
  3129. B:=TSQLBinaryExpression(CheckClass(U.WhereClause,TSQLBinaryExpression));
  3130. AssertEquals('Is null operation',boIs,B.Operation);
  3131. IE:=TSQLIdentifierExpression(CheckClass(B.Left,TSQLIdentifierExpression));
  3132. AssertIdentifierName('Correct field name','B',IE.Identifier);
  3133. L:=TSQLLiteralExpression(CheckClass(B.Right,TSQLLiteralExpression));
  3134. CheckClass(L.Literal,TSQLNullLiteral);
  3135. end;
  3136. { TTestInsertParser }
  3137. function TTestInsertParser.TestInsert(const ASource, ATable: String
  3138. ): TSQLInsertStatement;
  3139. begin
  3140. CreateParser(ASource);
  3141. FToFree:=Parser.Parse;
  3142. Result:=TSQLInsertStatement(CheckClass(FToFree,TSQLInsertStatement));
  3143. AssertIdentifierName('Correct table name',ATable,Result.TableName);
  3144. AssertEquals('End of stream reached',tsqlEOF,Parser.CurrentToken);
  3145. end;
  3146. procedure TTestInsertParser.TestInsertOneField;
  3147. Var
  3148. I : TSQLInsertStatement;
  3149. E : TSQLLiteralExpression;
  3150. L : TSQLIntegerLiteral;
  3151. begin
  3152. I:=TestInsert('INSERT INTO A (B) VALUES (1)','A');
  3153. AssertNotNull('Have fields',I.Fields);
  3154. AssertEquals('1 field',1,I.Fields.Count);
  3155. AssertIdentifierName('Correct field name','B',I.Fields[0]);
  3156. AssertNotNull('Have values',I.Values);
  3157. AssertEquals('Have 1 value',1,I.Values.Count);
  3158. E:=TSQLLiteralExpression(CheckClass(I.Values[0],TSQLLiteralExpression));
  3159. L:=TSQLIntegerLiteral(CheckClass(E.Literal,TSQLIntegerLiteral));
  3160. AssertEquals('Correct value',1,L.Value);
  3161. end;
  3162. procedure TTestInsertParser.TestInsertTwoFields;
  3163. Var
  3164. I : TSQLInsertStatement;
  3165. E : TSQLLiteralExpression;
  3166. L : TSQLIntegerLiteral;
  3167. begin
  3168. I:=TestInsert('INSERT INTO A (B,C) VALUES (1,2)','A');
  3169. AssertNotNull('Have fields',I.Fields);
  3170. AssertEquals('2 fields',2,I.Fields.Count);
  3171. AssertIdentifierName('Correct field 1 name','B',I.Fields[0]);
  3172. AssertIdentifierName('Correct field 2 name','C',I.Fields[1]);
  3173. AssertNotNull('Have values',I.Values);
  3174. AssertEquals('Have 2 values',2,I.Values.Count);
  3175. E:=TSQLLiteralExpression(CheckClass(I.Values[0],TSQLLiteralExpression));
  3176. L:=TSQLIntegerLiteral(CheckClass(E.Literal,TSQLIntegerLiteral));
  3177. AssertEquals('Correct value',1,L.Value);
  3178. E:=TSQLLiteralExpression(CheckClass(I.Values[1],TSQLLiteralExpression));
  3179. L:=TSQLIntegerLiteral(CheckClass(E.Literal,TSQLIntegerLiteral));
  3180. AssertEquals('Correct value',2,L.Value);
  3181. end;
  3182. procedure TTestInsertParser.TestInsertOneValue;
  3183. Var
  3184. I : TSQLInsertStatement;
  3185. E : TSQLLiteralExpression;
  3186. L : TSQLIntegerLiteral;
  3187. begin
  3188. I:=TestInsert('INSERT INTO A VALUES (1)','A');
  3189. AssertNull('Have no fields',I.Fields);
  3190. AssertNotNull('Have values',I.Values);
  3191. AssertEquals('Have 1 value',1,I.Values.Count);
  3192. E:=TSQLLiteralExpression(CheckClass(I.Values[0],TSQLLiteralExpression));
  3193. L:=TSQLIntegerLiteral(CheckClass(E.Literal,TSQLIntegerLiteral));
  3194. AssertEquals('Correct value',1,L.Value);
  3195. end;
  3196. procedure TTestInsertParser.TestInsertTwoValues;
  3197. Var
  3198. I : TSQLInsertStatement;
  3199. E : TSQLLiteralExpression;
  3200. L : TSQLIntegerLiteral;
  3201. begin
  3202. I:=TestInsert('INSERT INTO A VALUES (1,2)','A');
  3203. AssertNull('Have no fields',I.Fields);
  3204. AssertNotNull('Have values',I.Values);
  3205. AssertEquals('Have 2 values',2,I.Values.Count);
  3206. E:=TSQLLiteralExpression(CheckClass(I.Values[0],TSQLLiteralExpression));
  3207. L:=TSQLIntegerLiteral(CheckClass(E.Literal,TSQLIntegerLiteral));
  3208. AssertEquals('Correct value',1,L.Value);
  3209. E:=TSQLLiteralExpression(CheckClass(I.Values[1],TSQLLiteralExpression));
  3210. L:=TSQLIntegerLiteral(CheckClass(E.Literal,TSQLIntegerLiteral));
  3211. AssertEquals('Correct value',2,L.Value);
  3212. end;
  3213. { TTestSelectParser }
  3214. function TTestSelectParser.TestSelect(const ASource : String): TSQLSelectStatement;
  3215. begin
  3216. CreateParser(ASource);
  3217. FToFree:=Parser.Parse;
  3218. Result:=TSQLSelectStatement(CheckClass(FToFree,TSQLSelectStatement));
  3219. FSelect:=Result;
  3220. AssertEquals('End of stream reached',tsqlEOF,Parser.CurrentToken);
  3221. end;
  3222. procedure TTestSelectParser.TestSelectError(const ASource: String);
  3223. begin
  3224. FErrSource:=ASource;
  3225. AssertException(ESQLParser,@TestParseError);
  3226. end;
  3227. procedure TTestSelectParser.TestSelectFieldWithSchema;
  3228. Var
  3229. Expr: TSQLIdentifierExpression;
  3230. begin
  3231. TestSelect('SELECT S.A.B,C FROM S.A');
  3232. AssertEquals('Two fields',2,Select.Fields.Count);
  3233. AssertField(Select.Fields[0],'B');
  3234. Expr := ((Select.Fields[0] as TSQLSelectField).Expression as TSQLIdentifierExpression);
  3235. AssertEquals('Field[0] path has 3 identifiers',3,Expr.IdentifierPath.Count);
  3236. AssertEquals('Field[0] schema is S','S',Expr.IdentifierPath[0].Name);
  3237. AssertEquals('Field[0] table is A','A',Expr.IdentifierPath[1].Name);
  3238. AssertField(Select.Fields[1],'C');
  3239. AssertEquals('One table',1,Select.Tables.Count);
  3240. AssertTable(Select.Tables[0],'A','');
  3241. AssertEquals('Table path has 2 objects',2,(Select.Tables[0] as TSQLSimpleTableReference).ObjectNamePath.Count);
  3242. AssertEquals('Schema name = S','S',(Select.Tables[0] as TSQLSimpleTableReference).ObjectNamePath[0].Name);
  3243. end;
  3244. procedure TTestSelectParser.TestSelectFirst;
  3245. begin
  3246. // FireBird
  3247. TestSelect('SELECT FIRST 100 A FROM B');
  3248. AssertEquals('Limit style',Ord(lsFireBird),Ord(Select.Limit.Style));
  3249. AssertEquals('Limit FIRST 100',100,Select.Limit.First);
  3250. end;
  3251. procedure TTestSelectParser.TestSelectFirstSkip;
  3252. begin
  3253. // FireBird
  3254. TestSelect('SELECT FIRST 100 SKIP 200 A FROM B');
  3255. AssertEquals('Limit style',Ord(lsFireBird),Ord(Select.Limit.Style));
  3256. AssertEquals('Limit FIRST 100',100,Select.Limit.First);
  3257. AssertEquals('Limit SKIP 200',200,Select.Limit.Skip);
  3258. end;
  3259. procedure TTestSelectParser.TestSelectLimit;
  3260. begin
  3261. // MySQL&Postgres
  3262. TestSelect('SELECT A FROM B LIMIT 100');
  3263. AssertEquals('Limit style',Ord(lsPostgres),Ord(Select.Limit.Style));
  3264. AssertEquals('Limit RowCount 100',100,Select.Limit.RowCount);
  3265. end;
  3266. procedure TTestSelectParser.TestSelectLimitAll;
  3267. begin
  3268. // Postgres
  3269. TestSelect('SELECT A FROM B LIMIT ALL');
  3270. AssertEquals('Limit style',Ord(lsPostgres),Ord(Select.Limit.Style));
  3271. AssertEquals('Limit RowCount -1',-1,Select.Limit.RowCount);
  3272. end;
  3273. procedure TTestSelectParser.TestSelectLimitAllOffset;
  3274. begin
  3275. // Postgres
  3276. TestSelect('SELECT A FROM B LIMIT ALL OFFSET 200');
  3277. AssertEquals('Limit style',Ord(lsPostgres),Ord(Select.Limit.Style));
  3278. AssertEquals('Limit Offset 200',200,Select.Limit.Offset);
  3279. end;
  3280. procedure TTestSelectParser.TestSelectLimitOffset1;
  3281. begin
  3282. // MySQL
  3283. TestSelect('SELECT A FROM B LIMIT 200, 100');
  3284. AssertEquals('Limit style',Ord(lsPostgres),Ord(Select.Limit.Style));
  3285. AssertEquals('Limit RowCount 100',100,Select.Limit.RowCount);
  3286. AssertEquals('Limit Offset 200',200,Select.Limit.Offset);
  3287. end;
  3288. procedure TTestSelectParser.TestSelectLimitOffset2;
  3289. begin
  3290. // MySQL&Postgres
  3291. TestSelect('SELECT A FROM B LIMIT 100 OFFSET 200');
  3292. AssertEquals('Limit style',Ord(lsPostgres),Ord(Select.Limit.Style));
  3293. AssertEquals('Limit RowCount 100',100,Select.Limit.RowCount);
  3294. AssertEquals('Limit Offset 200',200,Select.Limit.Offset);
  3295. end;
  3296. procedure TTestSelectParser.TestSelectOffset;
  3297. begin
  3298. // Postgres
  3299. TestSelect('SELECT A FROM B OFFSET 200');
  3300. AssertEquals('Limit style',Ord(lsPostgres),Ord(Select.Limit.Style));
  3301. AssertEquals('Limit Offset 200',200,Select.Limit.Offset);
  3302. end;
  3303. procedure TTestSelectParser.TestSelectOneFieldOneTable;
  3304. begin
  3305. TestSelect('SELECT B FROM A');
  3306. AssertNull('No transaction name',Select.TransactionName);
  3307. AssertEquals('One field',1,Select.Fields.Count);
  3308. AssertField(Select.Fields[0],'B');
  3309. AssertEquals('One table',1,Select.Tables.Count);
  3310. AssertTable(Select.Tables[0],'A');
  3311. end;
  3312. procedure TTestSelectParser.TestSelectOneFieldOneTableTransaction;
  3313. begin
  3314. TestSelect('SELECT TRANSACTION C B FROM A');
  3315. AssertIdentifierName('Correct transaction name','C',Select.TransactionName);
  3316. AssertEquals('One field',1,Select.Fields.Count);
  3317. AssertField(Select.Fields[0],'B');
  3318. AssertEquals('One table',1,Select.Tables.Count);
  3319. AssertTable(Select.Tables[0],'A');
  3320. end;
  3321. procedure TTestSelectParser.TestSelectOneArrayFieldOneTable;
  3322. Var
  3323. E : TSQLIdentifierExpression;
  3324. begin
  3325. TestSelect('SELECT B[1] FROM A');
  3326. AssertEquals('One field',1,Select.Fields.Count);
  3327. AssertField(Select.Fields[0],'B');
  3328. E:=TSQLIdentifierExpression(CheckClass(TSQLSelectField(Select.Fields[0]).Expression,TSQLIdentifierExpression));
  3329. AssertEquals('Element 1 in array ',1,E.ElementIndex);
  3330. AssertEquals('One table',1,Select.Tables.Count);
  3331. AssertTable(Select.Tables[0],'A');
  3332. end;
  3333. procedure TTestSelectParser.TestSelectTwoFieldsOneTable;
  3334. begin
  3335. TestSelect('SELECT B,C FROM A');
  3336. AssertEquals('Two fields',2,Select.Fields.Count);
  3337. AssertField(Select.Fields[0],'B');
  3338. AssertField(Select.Fields[1],'C');
  3339. AssertEquals('One table',1,Select.Tables.Count);
  3340. AssertTable(Select.Tables[0],'A');
  3341. end;
  3342. procedure TTestSelectParser.TestSelectOneFieldAliasOneTable;
  3343. begin
  3344. TestSelect('SELECT B AS C FROM A');
  3345. AssertEquals('One field',1,Select.Fields.Count);
  3346. AssertField(Select.Fields[0],'B','C');
  3347. AssertEquals('One table',1,Select.Tables.Count);
  3348. AssertTable(Select.Tables[0],'A');
  3349. end;
  3350. procedure TTestSelectParser.TestSelectTwoFieldAliasesOneTable;
  3351. begin
  3352. TestSelect('SELECT B AS D,C AS E FROM A');
  3353. AssertEquals('Two fields',2,Select.Fields.Count);
  3354. AssertField(Select.Fields[0],'B','D');
  3355. AssertField(Select.Fields[1],'C','E');
  3356. AssertEquals('One table',1,Select.Tables.Count);
  3357. AssertTable(Select.Tables[0],'A');
  3358. end;
  3359. procedure TTestSelectParser.TestSelectOneTableFieldOneTable;
  3360. Var
  3361. Expr: TSQLIdentifierExpression;
  3362. begin
  3363. TestSelect('SELECT A.B FROM A');
  3364. AssertEquals('One field',1,Select.Fields.Count);
  3365. // Field supports linking/refering to a table
  3366. AssertField(Select.Fields[0],'B');
  3367. Expr := ((Select.Fields[0] as TSQLSelectField).Expression as TSQLIdentifierExpression);
  3368. AssertEquals('Field has explicit table',2,Expr.IdentifierPath.Count);
  3369. AssertEquals('Field has explicit table named A','A',Expr.IdentifierPath[0].Name);
  3370. AssertEquals('One table',1,Select.Tables.Count);
  3371. AssertTable(Select.Tables[0],'A');
  3372. end;
  3373. procedure TTestSelectParser.TestSelectTableWithSchema;
  3374. begin
  3375. TestSelect('SELECT B,C FROM S.A');
  3376. AssertEquals('Two fields',2,Select.Fields.Count);
  3377. AssertField(Select.Fields[0],'B');
  3378. AssertField(Select.Fields[1],'C');
  3379. AssertEquals('One table',1,Select.Tables.Count);
  3380. AssertTable(Select.Tables[0],'A','');
  3381. AssertEquals('Table path has 2 objects',2,(Select.Tables[0] as TSQLSimpleTableReference).ObjectNamePath.Count);
  3382. AssertEquals('Schema name = S','S',(Select.Tables[0] as TSQLSimpleTableReference).ObjectNamePath[0].Name);
  3383. end;
  3384. procedure TTestSelectParser.TestSelectTop;
  3385. begin
  3386. // MSSQL
  3387. TestSelect('SELECT TOP 100 A FROM B');
  3388. AssertEquals('Limit style',Ord(lsMSSQL),Ord(Select.Limit.Style));
  3389. AssertEquals('Limit TOP 100',100,Select.Limit.Top);
  3390. end;
  3391. procedure TTestSelectParser.TestSelectOneDistinctFieldOneTable;
  3392. begin
  3393. TestSelect('SELECT DISTINCT B FROM A');
  3394. AssertEquals('DISTINCT Query',True,Select.Distinct);
  3395. AssertEquals('One field',1,Select.Fields.Count);
  3396. AssertField(Select.Fields[0],'B');
  3397. AssertEquals('One table',1,Select.Tables.Count);
  3398. AssertTable(Select.Tables[0],'A');
  3399. end;
  3400. procedure TTestSelectParser.TestSelectOneAllFieldOneTable;
  3401. begin
  3402. TestSelect('SELECT ALL B FROM A');
  3403. AssertEquals('ALL Query',True,Select.All);
  3404. AssertEquals('One field',1,Select.Fields.Count);
  3405. AssertField(Select.Fields[0],'B');
  3406. AssertEquals('One table',1,Select.Tables.Count);
  3407. AssertTable(Select.Tables[0],'A');
  3408. end;
  3409. procedure TTestSelectParser.TestSelectAsteriskOneTable;
  3410. begin
  3411. TestSelect('SELECT * FROM A');
  3412. AssertEquals('One field',1,Select.Fields.Count);
  3413. CheckClass(Select.Fields[0],TSQLSelectAsterisk);
  3414. AssertEquals('One table',1,Select.Tables.Count);
  3415. AssertTable(Select.Tables[0],'A');
  3416. end;
  3417. procedure TTestSelectParser.TestSelectAsteriskWithPath;
  3418. begin
  3419. TestSelect('SELECT A.* FROM A');
  3420. AssertEquals('One field',1,Select.Fields.Count);
  3421. CheckClass(Select.Fields[0],TSQLSelectAsterisk);
  3422. AssertEquals('Path count = 1',1,TSQLSelectAsterisk(Select.Fields[0]).Expression.IdentifierPath.Count);
  3423. AssertEquals('Path table = A','A',TSQLSelectAsterisk(Select.Fields[0]).Expression.IdentifierPath[0].Name);
  3424. AssertEquals('One table',1,Select.Tables.Count);
  3425. AssertTable(Select.Tables[0],'A');
  3426. end;
  3427. procedure TTestSelectParser.TestSelectDistinctAsteriskOneTable;
  3428. begin
  3429. TestSelect('SELECT DISTINCT * FROM A');
  3430. AssertEquals('DISTINCT Query',True,Select.Distinct);
  3431. AssertEquals('One field',1,Select.Fields.Count);
  3432. CheckClass(Select.Fields[0],TSQLSelectAsterisk);
  3433. AssertEquals('One table',1,Select.Tables.Count);
  3434. AssertTable(Select.Tables[0],'A');
  3435. end;
  3436. procedure TTestSelectParser.TestSelectOneFieldOneTableAlias;
  3437. Var
  3438. Expr: TSQLIdentifierExpression;
  3439. begin
  3440. TestSelect('SELECT C.B FROM A C');
  3441. AssertEquals('One field',1,Select.Fields.Count);
  3442. AssertField(Select.Fields[0],'B');
  3443. Expr := ((Select.Fields[0] as TSQLSelectField).Expression as TSQLIdentifierExpression);
  3444. AssertEquals('Field has explicit table',2,Expr.IdentifierPath.Count);
  3445. AssertEquals('Field has explicit table named C','C',Expr.IdentifierPath[0].Name);
  3446. AssertEquals('One table',1,Select.Tables.Count);
  3447. AssertTable(Select.Tables[0],'A');
  3448. end;
  3449. procedure TTestSelectParser.TestSelectOneFieldOneTableAsAlias;
  3450. Var
  3451. Expr: TSQLIdentifierExpression;
  3452. begin
  3453. TestSelect('SELECT C.B FROM A AS C');
  3454. AssertEquals('One field',1,Select.Fields.Count);
  3455. AssertField(Select.Fields[0],'B');
  3456. Expr := ((Select.Fields[0] as TSQLSelectField).Expression as TSQLIdentifierExpression);
  3457. AssertEquals('Field has explicit table',2,Expr.IdentifierPath.Count);
  3458. AssertEquals('Field has explicit table named C','C',Expr.IdentifierPath[0].Name);
  3459. AssertEquals('One table',1,Select.Tables.Count);
  3460. AssertTable(Select.Tables[0],'A');
  3461. end;
  3462. procedure TTestSelectParser.TestSelectTwoFieldsTwoTables;
  3463. begin
  3464. TestSelect('SELECT B,C FROM A,D');
  3465. AssertEquals('Two fields',2,Select.Fields.Count);
  3466. AssertField(Select.Fields[0],'B');
  3467. AssertField(Select.Fields[1],'C');
  3468. AssertEquals('Two table',2,Select.Tables.Count);
  3469. AssertTable(Select.Tables[0],'A');
  3470. AssertTable(Select.Tables[1],'D');
  3471. end;
  3472. procedure TTestSelectParser.TestSelectTwoFieldsTwoTablesJoin;
  3473. Var
  3474. J : TSQLJoinTableReference;
  3475. begin
  3476. TestSelect('SELECT B,C FROM A JOIN D ON E=F');
  3477. AssertEquals('Two fields',2,Select.Fields.Count);
  3478. AssertField(Select.Fields[0],'B');
  3479. AssertField(Select.Fields[1],'C');
  3480. AssertEquals('One table',1,Select.Tables.Count);
  3481. J:=AssertJoin(Select.Tables[0],'A','D',jtNone);
  3482. AssertJoinOn(J.JoinClause,'E','F',boEq);
  3483. end;
  3484. procedure TTestSelectParser.TestSourcePosition;
  3485. begin
  3486. TestSelect('SELECT X FROM ABC');
  3487. AssertEquals('One table',1,Select.Tables.Count);
  3488. AssertEquals('Table source position = 1', 1, Select.Tables[0].SourceLine);
  3489. AssertEquals('Table source position = 15', 15, Select.Tables[0].SourcePos);
  3490. TestSelect('SELECT X'+sLineBreak+'FROM ABC');
  3491. AssertEquals('One table',1,Select.Tables.Count);
  3492. AssertEquals('Table source position = 2', 2, Select.Tables[0].SourceLine);
  3493. AssertEquals('Table source position = 6', 6, Select.Tables[0].SourcePos);
  3494. end;
  3495. procedure TTestSelectParser.TestSelectTwoFieldsTwoInnerTablesJoin;
  3496. Var
  3497. J : TSQLJoinTableReference;
  3498. begin
  3499. TestSelect('SELECT B,C FROM A INNER JOIN D ON E=F');
  3500. AssertEquals('Two fields',2,Select.Fields.Count);
  3501. AssertField(Select.Fields[0],'B');
  3502. AssertField(Select.Fields[1],'C');
  3503. AssertEquals('One table',1,Select.Tables.Count);
  3504. J:=AssertJoin(Select.Tables[0],'A','D',jtInner);
  3505. AssertJoinOn(J.JoinClause,'E','F',boEq);
  3506. end;
  3507. procedure TTestSelectParser.TestSelectTwoFieldsTwoFullOuterTablesJoin;
  3508. Var
  3509. J : TSQLJoinTableReference;
  3510. begin
  3511. TestSelect('SELECT B,C FROM A FULL OUTER JOIN D ON E=F');
  3512. AssertEquals('Two fields',2,Select.Fields.Count);
  3513. AssertField(Select.Fields[0],'B');
  3514. AssertField(Select.Fields[1],'C');
  3515. AssertEquals('One table',1,Select.Tables.Count);
  3516. J:=AssertJoin(Select.Tables[0],'A','D',jtFullOuter);
  3517. AssertJoinOn(J.JoinClause,'E','F',boEq);
  3518. end;
  3519. procedure TTestSelectParser.TestSelectTwoFieldsTwoFullTablesJoin;
  3520. Var
  3521. J : TSQLJoinTableReference;
  3522. begin
  3523. TestSelect('SELECT B,C FROM A FULL JOIN D ON E=F');
  3524. AssertEquals('Two fields',2,Select.Fields.Count);
  3525. AssertField(Select.Fields[0],'B');
  3526. AssertField(Select.Fields[1],'C');
  3527. AssertEquals('One table',1,Select.Tables.Count);
  3528. J:=AssertJoin(Select.Tables[0],'A','D',jtFullOuter);
  3529. AssertJoinOn(J.JoinClause,'E','F',boEq);
  3530. end;
  3531. procedure TTestSelectParser.TestSelectTwoFieldsTwoLeftTablesJoin;
  3532. Var
  3533. J : TSQLJoinTableReference;
  3534. begin
  3535. TestSelect('SELECT B,C FROM A LEFT JOIN D ON E=F');
  3536. AssertEquals('Two fields',2,Select.Fields.Count);
  3537. AssertField(Select.Fields[0],'B');
  3538. AssertField(Select.Fields[1],'C');
  3539. AssertEquals('One table',1,Select.Tables.Count);
  3540. J:=AssertJoin(Select.Tables[0],'A','D',jtLeft);
  3541. AssertJoinOn(J.JoinClause,'E','F',boEq);
  3542. end;
  3543. procedure TTestSelectParser.TestSelectTwoFieldsTwoRightTablesJoin;
  3544. Var
  3545. J : TSQLJoinTableReference;
  3546. begin
  3547. TestSelect('SELECT B,C FROM A RIGHT JOIN D ON E=F');
  3548. AssertEquals('Two fields',2,Select.Fields.Count);
  3549. AssertField(Select.Fields[0],'B');
  3550. AssertField(Select.Fields[1],'C');
  3551. AssertEquals('One table',1,Select.Tables.Count);
  3552. J:=AssertJoin(Select.Tables[0],'A','D',jtRight);
  3553. AssertJoinOn(J.JoinClause,'E','F',boEq);
  3554. end;
  3555. procedure TTestSelectParser.TestSelectTwoFieldsThreeTablesJoin;
  3556. Var
  3557. J : TSQLJoinTableReference;
  3558. begin
  3559. TestSelect('SELECT B,C FROM A JOIN D ON E=F JOIN G ON (H=I)');
  3560. AssertEquals('Two fields',2,Select.Fields.Count);
  3561. AssertField(Select.Fields[0],'B');
  3562. AssertField(Select.Fields[1],'C');
  3563. AssertEquals('One table',1,Select.Tables.Count);
  3564. j:=AssertJoin(Select.Tables[0],'','G',jtNone);
  3565. AssertJoinOn(J.JoinClause,'H','I',boEq);
  3566. J:=AssertJoin(J.Left,'A','D',jtNone);
  3567. AssertJoinOn(J.JoinClause,'E','F',boEq);
  3568. end;
  3569. procedure TTestSelectParser.TestSelectTwoFieldsBracketThreeTablesJoin;
  3570. Var
  3571. J : TSQLJoinTableReference;
  3572. begin
  3573. TestSelect('SELECT B,C FROM (A JOIN D ON E=F) JOIN G ON (H=I)');
  3574. AssertEquals('Two fields',2,Select.Fields.Count);
  3575. AssertField(Select.Fields[0],'B');
  3576. AssertField(Select.Fields[1],'C');
  3577. AssertEquals('One table',1,Select.Tables.Count);
  3578. j:=AssertJoin(Select.Tables[0],'','G',jtNone);
  3579. AssertJoinOn(J.JoinClause,'H','I',boEq);
  3580. J:=AssertJoin(J.Left,'A','D',jtNone);
  3581. AssertJoinOn(J.JoinClause,'E','F',boEq);
  3582. end;
  3583. procedure TTestSelectParser.TestSelectTwoFieldsThreeBracketTablesJoin;
  3584. Var
  3585. J : TSQLJoinTableReference;
  3586. begin
  3587. TestSelect('SELECT B,C FROM A JOIN (D JOIN G ON E=F) ON (H=I)');
  3588. AssertEquals('Two fields',2,Select.Fields.Count);
  3589. AssertField(Select.Fields[0],'B');
  3590. AssertField(Select.Fields[1],'C');
  3591. AssertEquals('One table',1,Select.Tables.Count);
  3592. j:=AssertJoin(Select.Tables[0],'A','',jtNone);
  3593. AssertJoinOn(J.JoinClause,'H','I',boEq);
  3594. j:=AssertJoin(J.Right,'D','G',jtNone);
  3595. AssertJoinOn(J.JoinClause,'E','F',boEq);
  3596. end;
  3597. procedure TTestSelectParser.TestAggregateCount;
  3598. begin
  3599. TestSelect('SELECT COUNT(B) FROM A');
  3600. AssertEquals('One field',1,Select.Fields.Count);
  3601. AssertEquals('One table',1,Select.Tables.Count);
  3602. AssertTable(Select.Tables[0],'A');
  3603. AssertAggregate(Select.Fields[0],afCount,'B',aoNone,'');
  3604. end;
  3605. procedure TTestSelectParser.TestAggregateCountAsterisk;
  3606. begin
  3607. TestSelect('SELECT COUNT(*) FROM A');
  3608. AssertEquals('One field',1,Select.Fields.Count);
  3609. AssertEquals('One table',1,Select.Tables.Count);
  3610. AssertTable(Select.Tables[0],'A');
  3611. AssertAggregate(Select.Fields[0],afCount,'',aoAsterisk,'');
  3612. end;
  3613. procedure TTestSelectParser.TestAggregateCountAll;
  3614. begin
  3615. TestSelect('SELECT COUNT(ALL B) FROM A');
  3616. AssertEquals('One field',1,Select.Fields.Count);
  3617. AssertEquals('One table',1,Select.Tables.Count);
  3618. AssertTable(Select.Tables[0],'A');
  3619. AssertAggregate(Select.Fields[0],afCount,'B',aoAll,'');
  3620. end;
  3621. procedure TTestSelectParser.TestAggregateCountDistinct;
  3622. begin
  3623. TestSelect('SELECT COUNT(DISTINCT B) FROM A');
  3624. AssertEquals('One field',1,Select.Fields.Count);
  3625. AssertEquals('One table',1,Select.Tables.Count);
  3626. AssertTable(Select.Tables[0],'A');
  3627. AssertAggregate(Select.Fields[0],afCount,'B',aoDistinct,'');
  3628. end;
  3629. procedure TTestSelectParser.TestAggregateMax;
  3630. begin
  3631. TestSelect('SELECT MAX(B) FROM A');
  3632. AssertEquals('One field',1,Select.Fields.Count);
  3633. AssertEquals('One table',1,Select.Tables.Count);
  3634. AssertTable(Select.Tables[0],'A');
  3635. AssertAggregate(Select.Fields[0],afMax,'B',aoNone,'');
  3636. end;
  3637. procedure TTestSelectParser.TestAggregateMaxAsterisk;
  3638. begin
  3639. TestSelectError('SELECT Max(*) FROM A');
  3640. end;
  3641. procedure TTestSelectParser.TestAggregateMaxAll;
  3642. begin
  3643. TestSelect('SELECT MAX(ALL B) FROM A');
  3644. AssertEquals('One field',1,Select.Fields.Count);
  3645. AssertEquals('One table',1,Select.Tables.Count);
  3646. AssertTable(Select.Tables[0],'A');
  3647. AssertAggregate(Select.Fields[0],afMax,'B',aoAll,'');
  3648. end;
  3649. procedure TTestSelectParser.TestAggregateMaxDistinct;
  3650. begin
  3651. TestSelect('SELECT MAX(DISTINCT B) FROM A');
  3652. AssertEquals('One field',1,Select.Fields.Count);
  3653. AssertEquals('One table',1,Select.Tables.Count);
  3654. AssertTable(Select.Tables[0],'A');
  3655. AssertAggregate(Select.Fields[0],afMax,'B',aoDistinct,'');
  3656. end;
  3657. procedure TTestSelectParser.TestAggregateMin;
  3658. begin
  3659. TestSelect('SELECT Min(B) FROM A');
  3660. AssertEquals('One field',1,Select.Fields.Count);
  3661. AssertEquals('One table',1,Select.Tables.Count);
  3662. AssertTable(Select.Tables[0],'A');
  3663. AssertAggregate(Select.Fields[0],afMin,'B',aoNone,'');
  3664. end;
  3665. procedure TTestSelectParser.TestAggregateMinAsterisk;
  3666. begin
  3667. TestSelectError('SELECT Min(*) FROM A');
  3668. end;
  3669. procedure TTestSelectParser.TestAggregateMinAll;
  3670. begin
  3671. TestSelect('SELECT Min(ALL B) FROM A');
  3672. AssertEquals('One field',1,Select.Fields.Count);
  3673. AssertEquals('One table',1,Select.Tables.Count);
  3674. AssertTable(Select.Tables[0],'A');
  3675. AssertAggregate(Select.Fields[0],afMin,'B',aoAll,'');
  3676. end;
  3677. procedure TTestSelectParser.TestAggregateMinDistinct;
  3678. begin
  3679. TestSelect('SELECT Min(DISTINCT B) FROM A');
  3680. AssertEquals('One field',1,Select.Fields.Count);
  3681. AssertEquals('One table',1,Select.Tables.Count);
  3682. AssertTable(Select.Tables[0],'A');
  3683. AssertAggregate(Select.Fields[0],afMin,'B',aoDistinct,'');
  3684. end;
  3685. procedure TTestSelectParser.TestAggregateSum;
  3686. begin
  3687. TestSelect('SELECT Sum(B) FROM A');
  3688. AssertEquals('One field',1,Select.Fields.Count);
  3689. AssertEquals('One table',1,Select.Tables.Count);
  3690. AssertTable(Select.Tables[0],'A');
  3691. AssertAggregate(Select.Fields[0],afSum,'B',aoNone,'');
  3692. end;
  3693. procedure TTestSelectParser.TestAggregateSumAsterisk;
  3694. begin
  3695. TestSelectError('SELECT Sum(*) FROM A');
  3696. end;
  3697. procedure TTestSelectParser.TestAggregateSumAll;
  3698. begin
  3699. TestSelect('SELECT Sum(ALL B) FROM A');
  3700. AssertEquals('One field',1,Select.Fields.Count);
  3701. AssertEquals('One table',1,Select.Tables.Count);
  3702. AssertTable(Select.Tables[0],'A');
  3703. AssertAggregate(Select.Fields[0],afSum,'B',aoAll,'');
  3704. end;
  3705. procedure TTestSelectParser.TestAggregateSumDistinct;
  3706. begin
  3707. TestSelect('SELECT Sum(DISTINCT B) FROM A');
  3708. AssertEquals('One field',1,Select.Fields.Count);
  3709. AssertEquals('One table',1,Select.Tables.Count);
  3710. AssertTable(Select.Tables[0],'A');
  3711. AssertAggregate(Select.Fields[0],afSum,'B',aoDistinct,'');
  3712. end;
  3713. procedure TTestSelectParser.TestAggregateAvg;
  3714. begin
  3715. TestSelect('SELECT Avg(B) FROM A');
  3716. AssertEquals('One field',1,Select.Fields.Count);
  3717. AssertEquals('One table',1,Select.Tables.Count);
  3718. AssertTable(Select.Tables[0],'A');
  3719. AssertAggregate(Select.Fields[0],afAvg,'B',aoNone,'');
  3720. end;
  3721. procedure TTestSelectParser.TestAggregateAvgAsterisk;
  3722. begin
  3723. TestSelectError('SELECT Avg(*) FROM A');
  3724. end;
  3725. procedure TTestSelectParser.TestAggregateAvgAll;
  3726. begin
  3727. TestSelect('SELECT Avg(ALL B) FROM A');
  3728. AssertEquals('One field',1,Select.Fields.Count);
  3729. AssertEquals('One table',1,Select.Tables.Count);
  3730. AssertTable(Select.Tables[0],'A');
  3731. AssertAggregate(Select.Fields[0],afAvg,'B',aoAll,'');
  3732. end;
  3733. procedure TTestSelectParser.TestAggregateAvgDistinct;
  3734. begin
  3735. TestSelect('SELECT Avg(DISTINCT B) FROM A');
  3736. AssertEquals('One field',1,Select.Fields.Count);
  3737. AssertEquals('One table',1,Select.Tables.Count);
  3738. AssertTable(Select.Tables[0],'A');
  3739. AssertAggregate(Select.Fields[0],afAvg,'B',aoDistinct,'');
  3740. end;
  3741. procedure TTestSelectParser.TestUpperConst;
  3742. Var
  3743. E : TSQLFunctionCallExpression;
  3744. L : TSQLLiteralExpression;
  3745. S : TSQLStringLiteral;
  3746. begin
  3747. TestSelect('SELECT UPPER(''a'') FROM A');
  3748. AssertEquals('One field',1,Select.Fields.Count);
  3749. AssertEquals('One table',1,Select.Tables.Count);
  3750. AssertTable(Select.Tables[0],'A');
  3751. CheckClass(Select.Fields[0],TSQLSelectField);
  3752. E:=TSQLFunctionCallExpression(CheckClass(TSQLSelectField(Select.Fields[0]).Expression,TSQLFunctionCallExpression));
  3753. AssertEquals('UPPER function name','UPPER',E.Identifier);
  3754. AssertEquals('One function element',1,E.Arguments.Count);
  3755. L:=TSQLLiteralExpression(CheckClass(E.Arguments[0],TSQLLiteralExpression));
  3756. S:=TSQLStringLiteral(CheckClass(L.Literal,TSQLStringLiteral));
  3757. AssertEquals('Correct constant','a',S.Value);
  3758. end;
  3759. procedure TTestSelectParser.TestUpperError;
  3760. begin
  3761. TestSelectError('SELECT UPPER(''A'',''B'') FROM C');
  3762. end;
  3763. procedure TTestSelectParser.TestGenID;
  3764. Var
  3765. E : TSQLGenIDExpression;
  3766. L : TSQLLiteralExpression;
  3767. S : TSQLIntegerLiteral;
  3768. begin
  3769. TestSelect('SELECT GEN_ID(GEN_B,1) FROM RDB$DATABASE');
  3770. AssertEquals('One field',1,Select.Fields.Count);
  3771. AssertEquals('One table',1,Select.Tables.Count);
  3772. AssertTable(Select.Tables[0],'RDB$DATABASE');
  3773. CheckClass(Select.Fields[0],TSQLSelectField);
  3774. E:=TSQLGenIDExpression(CheckClass(TSQLSelectField(Select.Fields[0]).Expression,TSQLGenIDExpression));
  3775. AssertIdentifierName('GenID generator function name','GEN_B',E.Generator);
  3776. L:=TSQLLiteralExpression(CheckClass(E.Value,TSQLLiteralExpression));
  3777. S:=TSQLIntegerLiteral(CheckClass(L.Literal,TSQLIntegerLiteral));
  3778. AssertEquals('Correct constant',1,S.Value);
  3779. end;
  3780. procedure TTestSelectParser.TestGenIDError1;
  3781. begin
  3782. TestSelectError('SELECT GEN_ID(''GEN_B'',1) FROM RDB$DATABASE');
  3783. end;
  3784. procedure TTestSelectParser.TestGenIDError2;
  3785. begin
  3786. TestSelectError('SELECT GEN_ID(''GEN_B'') FROM RDB$DATABASE');
  3787. end;
  3788. procedure TTestSelectParser.TestCastSimple;
  3789. var
  3790. C : TSQLCastExpression;
  3791. L : TSQLLiteralExpression;
  3792. S : TSQLIntegerLiteral;
  3793. begin
  3794. TestSelect('SELECT CAST(1 AS VARCHAR(5)) FROM A');
  3795. AssertEquals('One field',1,Select.Fields.Count);
  3796. AssertEquals('One table',1,Select.Tables.Count);
  3797. AssertTable(Select.Tables[0],'A');
  3798. CheckClass(Select.Fields[0],TSQLSelectField);
  3799. C:=TSQLCastExpression(CheckClass(TSQLSelectField(Select.Fields[0]).Expression,TSQLCastExpression));
  3800. L:=TSQLLiteralExpression(CheckClass(C.Value,TSQLLiteralExpression));
  3801. S:=TSQLIntegerLiteral(CheckClass(L.Literal,TSQLIntegerLiteral));
  3802. AssertEquals('Correct constant',1,S.Value);
  3803. AssertTypeDefaults(C.NewType,5);
  3804. AssertEquals('Correct type',sdtVarChar,C.NewType.DataType);
  3805. end;
  3806. procedure TTestSelectParser.DoExtractSimple(Expected: TSQLExtractElement);
  3807. var
  3808. E : TSQLExtractExpression;
  3809. I : TSQLIdentifierExpression;
  3810. begin
  3811. TestSelect('SELECT EXTRACT('+ExtractElementNames[Expected]+' FROM B) FROM A');
  3812. AssertEquals('One field',1,Select.Fields.Count);
  3813. AssertEquals('One table',1,Select.Tables.Count);
  3814. AssertTable(Select.Tables[0],'A');
  3815. CheckClass(Select.Fields[0],TSQLSelectField);
  3816. E:=TSQLExtractExpression(CheckClass(TSQLSelectField(Select.Fields[0]).Expression,TSQLExtractExpression));
  3817. I:=TSQLIdentifierExpression(CheckClass(E.Value,TSQLIdentifierExpression));
  3818. AssertIdentifierName('Correct field','B',I.Identifier);
  3819. FreeAndNil(FParser);
  3820. FreeAndNil(FSource);
  3821. FreeAndNil(FToFree);
  3822. end;
  3823. procedure TTestSelectParser.TestExtractSimple;
  3824. Var
  3825. E : TSQLExtractElement;
  3826. begin
  3827. For E:=Low(TSQLExtractElement) to High(TSQLExtractElement) do
  3828. DoExtractSimple(E);
  3829. end;
  3830. procedure TTestSelectParser.TestOrderByOneField;
  3831. begin
  3832. TestSelect('SELECT B FROM A ORDER BY C');
  3833. AssertEquals('One field',1,Select.Fields.Count);
  3834. AssertEquals('One table',1,Select.Tables.Count);
  3835. AssertField(Select.Fields[0],'B');
  3836. AssertTable(Select.Tables[0],'A');
  3837. AssertEquals('One order by field',1,Select.Orderby.Count);
  3838. AssertOrderBy(Select.OrderBy[0],'C',0,obAscending);
  3839. end;
  3840. procedure TTestSelectParser.TestOrderByTwoFields;
  3841. begin
  3842. TestSelect('SELECT B FROM A ORDER BY C,D');
  3843. AssertEquals('One field',1,Select.Fields.Count);
  3844. AssertEquals('One table',1,Select.Tables.Count);
  3845. AssertField(Select.Fields[0],'B');
  3846. AssertTable(Select.Tables[0],'A');
  3847. AssertEquals('Two order by fields',2,Select.Orderby.Count);
  3848. AssertOrderBy(Select.OrderBy[0],'C',0,obAscending);
  3849. AssertOrderBy(Select.OrderBy[1],'D',0,obAscending);
  3850. end;
  3851. procedure TTestSelectParser.TestOrderByThreeFields;
  3852. begin
  3853. TestSelect('SELECT B FROM A ORDER BY C,D,E');
  3854. AssertEquals('One field',1,Select.Fields.Count);
  3855. AssertEquals('One table',1,Select.Tables.Count);
  3856. AssertField(Select.Fields[0],'B');
  3857. AssertTable(Select.Tables[0],'A');
  3858. AssertEquals('Three order by fields',3,Select.Orderby.Count);
  3859. AssertOrderBy(Select.OrderBy[0],'C',0,obAscending);
  3860. AssertOrderBy(Select.OrderBy[1],'D',0,obAscending);
  3861. AssertOrderBy(Select.OrderBy[2],'E',0,obAscending);
  3862. end;
  3863. procedure TTestSelectParser.TestOrderByOneDescField;
  3864. begin
  3865. TestSelect('SELECT B FROM A ORDER BY C DESC');
  3866. AssertEquals('One field',1,Select.Fields.Count);
  3867. AssertEquals('One table',1,Select.Tables.Count);
  3868. AssertField(Select.Fields[0],'B');
  3869. AssertTable(Select.Tables[0],'A');
  3870. AssertEquals('One order by field',1,Select.Orderby.Count);
  3871. AssertOrderBy(Select.OrderBy[0],'C',0,obDescending);
  3872. end;
  3873. procedure TTestSelectParser.TestOrderByTwoDescFields;
  3874. begin
  3875. TestSelect('SELECT B FROM A ORDER BY C DESC, D DESCENDING');
  3876. AssertEquals('One field',1,Select.Fields.Count);
  3877. AssertEquals('One table',1,Select.Tables.Count);
  3878. AssertField(Select.Fields[0],'B');
  3879. AssertTable(Select.Tables[0],'A');
  3880. AssertEquals('Two order by fields',2,Select.Orderby.Count);
  3881. AssertOrderBy(Select.OrderBy[0],'C',0,obDescending);
  3882. AssertOrderBy(Select.OrderBy[1],'D',0,obDescending);
  3883. end;
  3884. procedure TTestSelectParser.TestOrderByThreeDescFields;
  3885. begin
  3886. TestSelect('SELECT B FROM A ORDER BY C DESC,D DESCENDING, E DESC');
  3887. AssertEquals('One field',1,Select.Fields.Count);
  3888. AssertEquals('One table',1,Select.Tables.Count);
  3889. AssertField(Select.Fields[0],'B');
  3890. AssertTable(Select.Tables[0],'A');
  3891. AssertEquals('Three order by fields',3,Select.Orderby.Count);
  3892. AssertOrderBy(Select.OrderBy[0],'C',0,obDescending);
  3893. AssertOrderBy(Select.OrderBy[1],'D',0,obDescending);
  3894. AssertOrderBy(Select.OrderBy[2],'E',0,obDescending);
  3895. end;
  3896. procedure TTestSelectParser.TestOrderByOneTableField;
  3897. begin
  3898. TestSelect('SELECT B FROM A ORDER BY C.D');
  3899. AssertEquals('One field',1,Select.Fields.Count);
  3900. AssertEquals('One table',1,Select.Tables.Count);
  3901. AssertField(Select.Fields[0],'B');
  3902. AssertTable(Select.Tables[0],'A');
  3903. AssertEquals('One order by field',1,Select.Orderby.Count);
  3904. // Field does not support linking/refering to a table, so the field name is
  3905. // assigned as C.D (instead of D with a <link to table C>)
  3906. AssertOrderBy(Select.OrderBy[0],'C.D',0,obAscending);
  3907. end;
  3908. procedure TTestSelectParser.TestOrderByOneColumn;
  3909. begin
  3910. TestSelect('SELECT B FROM A ORDER BY 1');
  3911. AssertEquals('One field',1,Select.Fields.Count);
  3912. AssertEquals('One table',1,Select.Tables.Count);
  3913. AssertField(Select.Fields[0],'B');
  3914. AssertTable(Select.Tables[0],'A');
  3915. AssertEquals('One order by field',1,Select.Orderby.Count);
  3916. AssertOrderBy(Select.OrderBy[0],'',1,obAscending);
  3917. end;
  3918. procedure TTestSelectParser.TestOrderByTwoColumns;
  3919. begin
  3920. TestSelect('SELECT B,C FROM A ORDER BY 1,2');
  3921. AssertEquals('Two fields',2,Select.Fields.Count);
  3922. AssertEquals('One table',1,Select.Tables.Count);
  3923. AssertField(Select.Fields[0],'B');
  3924. AssertField(Select.Fields[1],'C');
  3925. AssertTable(Select.Tables[0],'A');
  3926. AssertEquals('Two order by fields',2,Select.Orderby.Count);
  3927. AssertOrderBy(Select.OrderBy[0],'',1,obAscending);
  3928. AssertOrderBy(Select.OrderBy[1],'',2,obAscending);
  3929. end;
  3930. procedure TTestSelectParser.TestOrderByTwoColumnsDesc;
  3931. begin
  3932. TestSelect('SELECT B,C FROM A ORDER BY 1 DESC,2');
  3933. AssertEquals('Two fields',2,Select.Fields.Count);
  3934. AssertEquals('One table',1,Select.Tables.Count);
  3935. AssertField(Select.Fields[0],'B');
  3936. AssertField(Select.Fields[1],'C');
  3937. AssertTable(Select.Tables[0],'A');
  3938. AssertEquals('Two order by fields',2,Select.Orderby.Count);
  3939. AssertOrderBy(Select.OrderBy[0],'',1,obDescending);
  3940. AssertOrderBy(Select.OrderBy[1],'',2,obAscending);
  3941. end;
  3942. procedure TTestSelectParser.TestOrderByCollate;
  3943. Var
  3944. O : TSQLOrderByElement;
  3945. begin
  3946. TestSelect('SELECT B,C FROM A ORDER BY D COLLATE E');
  3947. AssertEquals('Two fields',2,Select.Fields.Count);
  3948. AssertEquals('One table',1,Select.Tables.Count);
  3949. AssertField(Select.Fields[0],'B');
  3950. AssertField(Select.Fields[1],'C');
  3951. AssertTable(Select.Tables[0],'A');
  3952. AssertEquals('One order by fields',1,Select.Orderby.Count);
  3953. O:=AssertOrderBy(Select.OrderBy[0],'D',0,obAscending);
  3954. AssertIdentifierName('Correct collation','E',O.Collation);
  3955. end;
  3956. procedure TTestSelectParser.TestOrderByCollateDesc;
  3957. Var
  3958. O : TSQLOrderByElement;
  3959. begin
  3960. TestSelect('SELECT B,C FROM A ORDER BY D COLLATE E');
  3961. AssertEquals('Two fields',2,Select.Fields.Count);
  3962. AssertEquals('One table',1,Select.Tables.Count);
  3963. AssertField(Select.Fields[0],'B');
  3964. AssertField(Select.Fields[1],'C');
  3965. AssertTable(Select.Tables[0],'A');
  3966. AssertEquals('One order by fields',1,Select.Orderby.Count);
  3967. O:=AssertOrderBy(Select.OrderBy[0],'D',0,obAscending);
  3968. AssertIdentifierName('Correct collation','E',O.Collation);
  3969. end;
  3970. procedure TTestSelectParser.TestOrderByCollateDescTwoFields;
  3971. Var
  3972. O : TSQLOrderByElement;
  3973. begin
  3974. TestSelect('SELECT B,C FROM A ORDER BY D COLLATE E DESC,F COLLATE E');
  3975. AssertEquals('Two fields',2,Select.Fields.Count);
  3976. AssertEquals('One table',1,Select.Tables.Count);
  3977. AssertField(Select.Fields[0],'B');
  3978. AssertField(Select.Fields[1],'C');
  3979. AssertTable(Select.Tables[0],'A');
  3980. AssertEquals('Two order by fields',2,Select.Orderby.Count);
  3981. O:=AssertOrderBy(Select.OrderBy[0],'D',0,obDescending);
  3982. AssertIdentifierName('Correct collation','E',O.Collation);
  3983. O:=AssertOrderBy(Select.OrderBy[1],'F',0,obAscending);
  3984. AssertIdentifierName('Correct collation','E',O.Collation);
  3985. end;
  3986. procedure TTestSelectParser.TestGroupByOne;
  3987. begin
  3988. TestSelect('SELECT B,COUNT(C) AS THECOUNT FROM A GROUP BY B');
  3989. AssertEquals('Two fields',2,Select.Fields.Count);
  3990. AssertEquals('One group by field',1,Select.GroupBy.Count);
  3991. AssertIdentifierName('Correct group by field','B',Select.GroupBy[0]);
  3992. AssertField(Select.Fields[0],'B');
  3993. AssertAggregate(Select.Fields[1],afCount,'C',aoNone,'THECOUNT');
  3994. end;
  3995. procedure TTestSelectParser.TestGroupByTwo;
  3996. begin
  3997. TestSelect('SELECT B,C,SUM(D) AS THESUM FROM A GROUP BY B,C');
  3998. AssertEquals('Three fields',3,Select.Fields.Count);
  3999. AssertEquals('One group two fields',2,Select.GroupBy.Count);
  4000. AssertIdentifierName('Correct first group by field','B',Select.GroupBy[0]);
  4001. AssertIdentifierName('Correct second group by field','C',Select.GroupBy[1]);
  4002. AssertField(Select.Fields[0],'B');
  4003. AssertField(Select.Fields[1],'C');
  4004. AssertAggregate(Select.Fields[2],afSum,'D',aoNone,'THESUM');
  4005. end;
  4006. procedure TTestSelectParser.TestHavingOne;
  4007. Var
  4008. H : TSQLBinaryExpression;
  4009. L : TSQLLiteralExpression;
  4010. S : TSQLIntegerLiteral;
  4011. begin
  4012. TestSelect('SELECT B,COUNT(C) AS THECOUNT FROM A GROUP BY B HAVING COUNT(C)>1');
  4013. AssertEquals('Two fields',2,Select.Fields.Count);
  4014. AssertEquals('One group by field',1,Select.GroupBy.Count);
  4015. AssertIdentifierName('Correct group by field','B',Select.GroupBy[0]);
  4016. AssertField(Select.Fields[0],'B');
  4017. AssertAggregate(Select.Fields[1],afCount,'C',aoNone,'THECOUNT');
  4018. AssertNotNull('Have having',Select.Having);
  4019. H:=TSQLBinaryExpression(CheckClass(Select.Having,TSQLBinaryExpression));
  4020. AssertEquals('Larger than',boGT,H.Operation);
  4021. L:=TSQLLiteralExpression(CheckClass(H.Right,TSQLLiteralExpression));
  4022. S:=TSQLIntegerLiteral(CheckClass(L.Literal,TSQLIntegerLiteral));
  4023. AssertEquals('One',1,S.Value);
  4024. AssertAggregateExpression(H.Left,afCount,'C',aoNone);
  4025. end;
  4026. procedure TTestSelectParser.TestNoTable;
  4027. Var
  4028. F : TSQLSelectField;
  4029. L : TSQLIntegerLiteral;
  4030. begin
  4031. TestSelect('SELECT 1');
  4032. AssertEquals('0 tables in select',0,Select.Tables.Count);
  4033. AssertEquals('1 field in select',1,Select.Fields.Count);
  4034. AssertNotNull('Have field',Select.Fields[0]);
  4035. F:=TSQLSelectField(CheckClass(Select.Fields[0],TSQLSelectField));
  4036. AssertNotNull('Have field expresssion,',F.Expression);
  4037. L:=TSQLIntegerLiteral(AssertLiteralExpr('Field is a literal',F.Expression,TSQLIntegerLiteral));
  4038. AssertEquals('SELECT 1',1,L.Value);
  4039. end;
  4040. procedure TTestSelectParser.TestUnionSimple;
  4041. Var
  4042. S : TSQLSelectStatement;
  4043. begin
  4044. TestSelect('SELECT B FROM A UNION SELECT C FROM D');
  4045. AssertEquals('One field',1,Select.Fields.Count);
  4046. AssertField(Select.Fields[0],'B');
  4047. AssertEquals('One table',1,Select.Tables.Count);
  4048. AssertTable(Select.Tables[0],'A');
  4049. S:=TSQLSelectStatement(CheckClass(Select.Union,TSQLSelectStatement));
  4050. AssertEquals('One field',1,S.Fields.Count);
  4051. AssertField(S.Fields[0],'C');
  4052. AssertEquals('One table',1,S.Tables.Count);
  4053. AssertTable(S.Tables[0],'D');
  4054. AssertEquals('No UNION ALL : ',False,Select.UnionAll)
  4055. end;
  4056. procedure TTestSelectParser.TestUnionSimpleAll;
  4057. Var
  4058. S : TSQLSelectStatement;
  4059. begin
  4060. TestSelect('SELECT B FROM A UNION ALL SELECT C FROM D');
  4061. AssertEquals('One field',1,Select.Fields.Count);
  4062. AssertField(Select.Fields[0],'B');
  4063. AssertEquals('One table',1,Select.Tables.Count);
  4064. AssertTable(Select.Tables[0],'A');
  4065. S:=TSQLSelectStatement(CheckClass(Select.Union,TSQLSelectStatement));
  4066. AssertEquals('One field',1,S.Fields.Count);
  4067. AssertField(S.Fields[0],'C');
  4068. AssertEquals('One table',1,S.Tables.Count);
  4069. AssertTable(S.Tables[0],'D');
  4070. AssertEquals('UNION ALL : ',True,Select.UnionAll)
  4071. end;
  4072. procedure TTestSelectParser.TestUnionSimpleOrderBy;
  4073. Var
  4074. S : TSQLSelectStatement;
  4075. begin
  4076. TestSelect('SELECT B FROM A UNION SELECT C FROM D ORDER BY 1');
  4077. AssertEquals('One field',1,Select.Fields.Count);
  4078. AssertField(Select.Fields[0],'B');
  4079. AssertEquals('One table',1,Select.Tables.Count);
  4080. AssertTable(Select.Tables[0],'A');
  4081. AssertOrderBy(Select.OrderBy[0],'',1,obAscending);
  4082. S:=TSQLSelectStatement(CheckClass(Select.Union,TSQLSelectStatement));
  4083. AssertEquals('One field',1,S.Fields.Count);
  4084. AssertField(S.Fields[0],'C');
  4085. AssertEquals('One table',1,S.Tables.Count);
  4086. AssertTable(S.Tables[0],'D');
  4087. end;
  4088. procedure TTestSelectParser.TestUnionDouble;
  4089. Var
  4090. S : TSQLSelectStatement;
  4091. begin
  4092. TestSelect('SELECT B FROM A UNION SELECT C FROM D UNION SELECT E FROM F ORDER BY 1');
  4093. AssertEquals('One field',1,Select.Fields.Count);
  4094. AssertField(Select.Fields[0],'B');
  4095. AssertEquals('One table',1,Select.Tables.Count);
  4096. AssertTable(Select.Tables[0],'A');
  4097. AssertOrderBy(Select.OrderBy[0],'',1,obAscending);
  4098. S:=TSQLSelectStatement(CheckClass(Select.Union,TSQLSelectStatement));
  4099. AssertEquals('One field',1,S.Fields.Count);
  4100. AssertField(S.Fields[0],'C');
  4101. AssertEquals('One table',1,S.Tables.Count);
  4102. AssertTable(S.Tables[0],'D');
  4103. S:=TSQLSelectStatement(CheckClass(S.Union,TSQLSelectStatement));
  4104. AssertEquals('One field',1,S.Fields.Count);
  4105. AssertField(S.Fields[0],'E');
  4106. AssertEquals('One table',1,S.Tables.Count);
  4107. AssertTable(S.Tables[0],'F');
  4108. end;
  4109. procedure TTestSelectParser.TestUnionError1;
  4110. begin
  4111. TestSelectError('SELECT B FROM A ORDER BY B UNION SELECT C FROM D');
  4112. end;
  4113. procedure TTestSelectParser.TestUnionError2;
  4114. begin
  4115. TestSelectError('SELECT B FROM A UNION SELECT C,E FROM D');
  4116. end;
  4117. procedure TTestSelectParser.TestPlanOrderNatural;
  4118. Var
  4119. E : TSQLSelectPlanExpr;
  4120. N : TSQLSelectNaturalPLan;
  4121. begin
  4122. TestSelect('SELECT A FROM B PLAN SORT (B NATURAL)');
  4123. E:=TSQLSelectPlanExpr(CheckClass(Select.Plan,TSQLSelectPlanExpr));
  4124. AssertEquals('One plan item',1,E.Items.Count);
  4125. AssertEquals('Correct plan type',pjtSort,E.JoinType);
  4126. N:=TSQLSelectNaturalPLan(CheckClass(E.Items[0],TSQLSelectNaturalPLan));
  4127. AssertIdentifierName('Correct table','B',N.TableName);
  4128. end;
  4129. procedure TTestSelectParser.TestPlanOrderOrder;
  4130. Var
  4131. E : TSQLSelectPlanExpr;
  4132. O : TSQLSelectOrderedPLan;
  4133. begin
  4134. TestSelect('SELECT A FROM B PLAN SORT (B ORDER C)');
  4135. E:=TSQLSelectPlanExpr(CheckClass(Select.Plan,TSQLSelectPlanExpr));
  4136. AssertEquals('One plan item',1,E.Items.Count);
  4137. AssertEquals('Correct plan type',pjtSort,E.JoinType);
  4138. O:=TSQLSelectOrderedPLan(CheckClass(E.Items[0],TSQLSelectOrderedPLan));
  4139. AssertIdentifierName('Correct table','B',O.TableName);
  4140. AssertIdentifierName('Correct table','C',O.OrderIndex);
  4141. end;
  4142. procedure TTestSelectParser.TestPlanOrderIndex1;
  4143. Var
  4144. E : TSQLSelectPlanExpr;
  4145. O : TSQLSelectIndexedPLan;
  4146. begin
  4147. TestSelect('SELECT A FROM B PLAN SORT (B INDEX (C))');
  4148. E:=TSQLSelectPlanExpr(CheckClass(Select.Plan,TSQLSelectPlanExpr));
  4149. AssertEquals('One plan item',1,E.Items.Count);
  4150. AssertEquals('Correct plan type',pjtSort,E.JoinType);
  4151. O:=TSQLSelectIndexedPLan(CheckClass(E.Items[0],TSQLSelectIndexedPlan));
  4152. AssertIdentifierName('Correct table','B',O.TableName);
  4153. AssertEquals('Correct index count',1,O.Indexes.Count);
  4154. AssertIdentifierName('Correct table','C',O.Indexes[0]);
  4155. end;
  4156. procedure TTestSelectParser.TestPlanOrderIndex2;
  4157. Var
  4158. E : TSQLSelectPlanExpr;
  4159. O : TSQLSelectIndexedPLan;
  4160. begin
  4161. TestSelect('SELECT A FROM B PLAN SORT (B INDEX (C,D))');
  4162. E:=TSQLSelectPlanExpr(CheckClass(Select.Plan,TSQLSelectPlanExpr));
  4163. AssertEquals('One plan item',1,E.Items.Count);
  4164. AssertEquals('Correct plan type',pjtSort,E.JoinType);
  4165. O:=TSQLSelectIndexedPLan(CheckClass(E.Items[0],TSQLSelectIndexedPlan));
  4166. AssertIdentifierName('Correct table','B',O.TableName);
  4167. AssertEquals('Correct index count',2,O.Indexes.Count);
  4168. AssertIdentifierName('Correct table','C',O.Indexes[0]);
  4169. AssertIdentifierName('Correct table','D',O.Indexes[1]);
  4170. end;
  4171. procedure TTestSelectParser.TestPlanJoinNatural;
  4172. Var
  4173. E : TSQLSelectPlanExpr;
  4174. N : TSQLSelectNaturalPLan;
  4175. O : TSQLSelectOrderedPLan;
  4176. begin
  4177. TestSelect('SELECT A FROM B PLAN JOIN (B NATURAL, C ORDER D)');
  4178. E:=TSQLSelectPlanExpr(CheckClass(Select.Plan,TSQLSelectPlanExpr));
  4179. AssertEquals('One plan item',2,E.Items.Count);
  4180. AssertEquals('Correct plan type',pjtJoin,E.JoinType);
  4181. N:=TSQLSelectNaturalPLan(CheckClass(E.Items[0],TSQLSelectNaturalPlan));
  4182. AssertIdentifierName('Correct table','B',N.TableName);
  4183. O:=TSQLSelectOrderedPLan(CheckClass(E.Items[1],TSQLSelectOrderedPlan));
  4184. AssertIdentifierName('Correct table','C',O.TableName);
  4185. AssertIdentifierName('Correct index','D',O.OrderIndex);
  4186. end;
  4187. procedure TTestSelectParser.TestPlanDefaultNatural;
  4188. Var
  4189. E : TSQLSelectPlanExpr;
  4190. N : TSQLSelectNaturalPLan;
  4191. O : TSQLSelectOrderedPLan;
  4192. begin
  4193. TestSelect('SELECT A FROM B PLAN (B NATURAL, C ORDER D)');
  4194. E:=TSQLSelectPlanExpr(CheckClass(Select.Plan,TSQLSelectPlanExpr));
  4195. AssertEquals('One plan item',2,E.Items.Count);
  4196. AssertEquals('Correct plan type',pjtJoin,E.JoinType);
  4197. N:=TSQLSelectNaturalPLan(CheckClass(E.Items[0],TSQLSelectNaturalPlan));
  4198. AssertIdentifierName('Correct table','B',N.TableName);
  4199. O:=TSQLSelectOrderedPLan(CheckClass(E.Items[1],TSQLSelectOrderedPlan));
  4200. AssertIdentifierName('Correct table','C',O.TableName);
  4201. AssertIdentifierName('Correct index','D',O.OrderIndex);
  4202. end;
  4203. procedure TTestSelectParser.TestPlanMergeNatural;
  4204. Var
  4205. E : TSQLSelectPlanExpr;
  4206. N : TSQLSelectNaturalPLan;
  4207. O : TSQLSelectOrderedPLan;
  4208. begin
  4209. TestSelect('SELECT A FROM B PLAN MERGE (B NATURAL, C ORDER D)');
  4210. E:=TSQLSelectPlanExpr(CheckClass(Select.Plan,TSQLSelectPlanExpr));
  4211. AssertEquals('One plan item',2,E.Items.Count);
  4212. AssertEquals('Correct plan type',pjtMerge,E.JoinType);
  4213. N:=TSQLSelectNaturalPLan(CheckClass(E.Items[0],TSQLSelectNaturalPlan));
  4214. AssertIdentifierName('Correct table','B',N.TableName);
  4215. O:=TSQLSelectOrderedPLan(CheckClass(E.Items[1],TSQLSelectOrderedPlan));
  4216. AssertIdentifierName('Correct table','C',O.TableName);
  4217. AssertIdentifierName('Correct index','D',O.OrderIndex);
  4218. end;
  4219. procedure TTestSelectParser.TestPlanMergeNested;
  4220. Var
  4221. E,EN : TSQLSelectPlanExpr;
  4222. N : TSQLSelectNaturalPLan;
  4223. I : TSQLSelectIndexedPLan;
  4224. begin
  4225. TestSelect('SELECT A FROM B PLAN MERGE (SORT (B NATURAL), SORT (JOIN (D NATURAL, E INDEX (F))))');
  4226. E:=TSQLSelectPlanExpr(CheckClass(Select.Plan,TSQLSelectPlanExpr));
  4227. AssertEquals('Two plan items',2,E.Items.Count);
  4228. AssertEquals('Correct overall plan type',pjtMerge,E.JoinType);
  4229. // SORT (B NATURAL)
  4230. EN:=TSQLSelectPlanExpr(CheckClass(E.Items[0],TSQLSelectPlanExpr));
  4231. AssertEquals('Correct plan type Item 1',pjtSort,EN.JoinType);
  4232. AssertEquals('On plan item in item 1',1,EN.Items.Count);
  4233. N:=TSQLSelectNaturalPLan(CheckClass(EN.Items[0],TSQLSelectNaturalPlan));
  4234. AssertIdentifierName('Correct table','B',N.TableName);
  4235. // SORT (JOIN (D...
  4236. EN:=TSQLSelectPlanExpr(CheckClass(E.Items[1],TSQLSelectPlanExpr));
  4237. AssertEquals('Correct plan type item 2',pjtSort,EN.JoinType);
  4238. AssertEquals('One plan item in item 2',1,EN.Items.Count);
  4239. // JOIN (D NATURAL, E
  4240. E:=TSQLSelectPlanExpr(CheckClass(EN.Items[0],TSQLSelectPlanExpr));
  4241. AssertEquals('Correct plan type',pjtJoin,E.JoinType);
  4242. AssertEquals('Two plan items in item 2',2,E.Items.Count);
  4243. N:=TSQLSelectNaturalPLan(CheckClass(E.Items[0],TSQLSelectNaturalPlan));
  4244. AssertIdentifierName('Correct table','D',N.TableName);
  4245. // E INDEX (F)
  4246. I:=TSQLSelectIndexedPLan(CheckClass(E.Items[1],TSQLSelectIndexedPlan));
  4247. AssertIdentifierName('Correct table','E',I.TableName);
  4248. AssertEquals('Correct index count for table E',1,I.Indexes.Count);
  4249. AssertIdentifierName('Correct index for table E','F',I.Indexes[0]);
  4250. end;
  4251. procedure TTestSelectParser.TestSubSelect;
  4252. Var
  4253. F : TSQLSelectField;
  4254. E : TSQLSelectExpression;
  4255. S : TSQLSelectStatement;
  4256. begin
  4257. TestSelect('SELECT A,(SELECT C FROM D WHERE E=A) AS THECOUNT FROM B');
  4258. AssertEquals('1 table in select',1,Select.Tables.Count);
  4259. AssertTable(Select.Tables[0],'B','');
  4260. AssertEquals('2 fields in select',2,Select.Fields.Count);
  4261. AssertField(Select.Fields[0],'A','');
  4262. F:=TSQLSelectField(CheckClass(Select.fields[1],TSQLSelectField));
  4263. AssertIdentifierName('Correct alias name for subselect','THECOUNT',F.AliasName);
  4264. E:=TSQLSelectExpression(CheckClass(F.Expression,TSQLSelectExpression));
  4265. S:=TSQLSelectStatement(CheckClass(E.Select,TSQLSelectStatement));
  4266. AssertEquals('1 field in subselect',1,S.Fields.Count);
  4267. AssertField(S.Fields[0],'C','');
  4268. AssertEquals('1 table in subselect',1,S.Tables.Count);
  4269. AssertTable(S.Tables[0],'D','');
  4270. end;
  4271. procedure TTestSelectParser.TestWhereExists;
  4272. Var
  4273. E : TSQLExistsExpression;
  4274. S : TSQLSelectStatement;
  4275. begin
  4276. TestSelect('SELECT A FROM B WHERE EXISTS (SELECT C FROM D WHERE E=A)');
  4277. AssertEquals('1 table in select',1,Select.Tables.Count);
  4278. AssertTable(Select.Tables[0],'B','');
  4279. AssertEquals('1 fields in select',1,Select.Fields.Count);
  4280. AssertField(Select.Fields[0],'A','');
  4281. E:=TSQLExistsExpression(CheckClass(Select.Where,TSQLExistsExpression));
  4282. S:=TSQLSelectStatement(CheckClass(E.Select,TSQLSelectStatement));
  4283. AssertEquals('1 field in subselect',1,S.Fields.Count);
  4284. AssertField(S.Fields[0],'C','');
  4285. AssertEquals('1 table in subselect',1,S.Tables.Count);
  4286. AssertTable(S.Tables[0],'D','');
  4287. end;
  4288. procedure TTestSelectParser.TestWhereSingular;
  4289. Var
  4290. E : TSQLSingularExpression;
  4291. S : TSQLSelectStatement;
  4292. begin
  4293. TestSelect('SELECT A FROM B WHERE SINGULAR (SELECT C FROM D WHERE E=A)');
  4294. AssertEquals('1 table in select',1,Select.Tables.Count);
  4295. AssertTable(Select.Tables[0],'B','');
  4296. AssertEquals('1 fields in select',1,Select.Fields.Count);
  4297. AssertField(Select.Fields[0],'A','');
  4298. E:=TSQLSingularExpression(CheckClass(Select.Where,TSQLSingularExpression));
  4299. S:=TSQLSelectStatement(CheckClass(E.Select,TSQLSelectStatement));
  4300. AssertEquals('1 field in subselect',1,S.Fields.Count);
  4301. AssertField(S.Fields[0],'C','');
  4302. AssertEquals('1 table in subselect',1,S.Tables.Count);
  4303. AssertTable(S.Tables[0],'D','');
  4304. end;
  4305. procedure TTestSelectParser.TestWhereAll;
  4306. Var
  4307. E : TSQLAllExpression;
  4308. S : TSQLSelectStatement;
  4309. B : TSQLBinaryExpression;
  4310. begin
  4311. TestSelect('SELECT A FROM B WHERE A > ALL (SELECT C FROM D WHERE E=F)');
  4312. AssertEquals('1 table in select',1,Select.Tables.Count);
  4313. AssertTable(Select.Tables[0],'B','');
  4314. AssertEquals('1 fields in select',1,Select.Fields.Count);
  4315. AssertField(Select.Fields[0],'A','');
  4316. B:=TSQLBinaryExpression(CheckClass(Select.Where,TSQLBinaryExpression));
  4317. AssertEquals('Correct operation',boGT,B.Operation);
  4318. E:=TSQLAllExpression(CheckClass(B.right,TSQLAllExpression));
  4319. S:=TSQLSelectStatement(CheckClass(E.Select,TSQLSelectStatement));
  4320. AssertEquals('1 field in subselect',1,S.Fields.Count);
  4321. AssertField(S.Fields[0],'C','');
  4322. AssertEquals('1 table in subselect',1,S.Tables.Count);
  4323. AssertTable(S.Tables[0],'D','');
  4324. end;
  4325. procedure TTestSelectParser.TestWhereAny;
  4326. Var
  4327. E : TSQLANyExpression;
  4328. S : TSQLSelectStatement;
  4329. B : TSQLBinaryExpression;
  4330. begin
  4331. TestSelect('SELECT A FROM B WHERE A > ANY (SELECT C FROM D WHERE E=F)');
  4332. AssertEquals('1 table in select',1,Select.Tables.Count);
  4333. AssertTable(Select.Tables[0],'B','');
  4334. AssertEquals('1 fields in select',1,Select.Fields.Count);
  4335. AssertField(Select.Fields[0],'A','');
  4336. B:=TSQLBinaryExpression(CheckClass(Select.Where,TSQLBinaryExpression));
  4337. AssertEquals('Correct operation',boGT,B.Operation);
  4338. E:=TSQLAnyExpression(CheckClass(B.right,TSQLANyExpression));
  4339. S:=TSQLSelectStatement(CheckClass(E.Select,TSQLSelectStatement));
  4340. AssertEquals('1 field in subselect',1,S.Fields.Count);
  4341. AssertField(S.Fields[0],'C','');
  4342. AssertEquals('1 table in subselect',1,S.Tables.Count);
  4343. AssertTable(S.Tables[0],'D','');
  4344. end;
  4345. procedure TTestSelectParser.TestWhereSome;
  4346. Var
  4347. E : TSQLSomeExpression;
  4348. S : TSQLSelectStatement;
  4349. B : TSQLBinaryExpression;
  4350. begin
  4351. TestSelect('SELECT A FROM B WHERE A > SOME (SELECT C FROM D WHERE E=F)');
  4352. AssertEquals('1 table in select',1,Select.Tables.Count);
  4353. AssertTable(Select.Tables[0],'B','');
  4354. AssertEquals('1 fields in select',1,Select.Fields.Count);
  4355. AssertField(Select.Fields[0],'A','');
  4356. B:=TSQLBinaryExpression(CheckClass(Select.Where,TSQLBinaryExpression));
  4357. AssertEquals('Correct operation',boGT,B.Operation);
  4358. E:=TSQLSomeExpression(CheckClass(B.right,TSQLSomeExpression));
  4359. S:=TSQLSelectStatement(CheckClass(E.Select,TSQLSelectStatement));
  4360. AssertEquals('1 field in subselect',1,S.Fields.Count);
  4361. AssertField(S.Fields[0],'C','');
  4362. AssertEquals('1 table in subselect',1,S.Tables.Count);
  4363. AssertTable(S.Tables[0],'D','');
  4364. end;
  4365. procedure TTestSelectParser.TestParam;
  4366. Var
  4367. F : TSQLSelectField;
  4368. P : TSQLParameterExpression;
  4369. begin
  4370. TestSelect('SELECT :A FROM B');
  4371. AssertEquals('1 table in select',1,Select.Tables.Count);
  4372. AssertTable(Select.Tables[0],'B','');
  4373. AssertEquals('1 fields in select',1,Select.Fields.Count);
  4374. AssertNotNull('Have field',Select.Fields[0]);
  4375. F:=TSQLSelectField(CheckClass(Select.Fields[0],TSQLSelectField));
  4376. AssertNotNull('Have field expresssion,',F.Expression);
  4377. P:=TSQLParameterExpression(CheckClass(F.Expression,TSQLParameterExpression));
  4378. AssertIdentifierName('Correct parameter name','A',P.Identifier);
  4379. end;
  4380. procedure TTestSelectParser.TestParamExpr;
  4381. Var
  4382. F : TSQLSelectField;
  4383. P : TSQLParameterExpression;
  4384. B : TSQLBinaryExpression;
  4385. begin
  4386. TestSelect('SELECT :A + 1 FROM B');
  4387. AssertEquals('1 table in select',1,Select.Tables.Count);
  4388. AssertTable(Select.Tables[0],'B','');
  4389. AssertEquals('1 fields in select',1,Select.Fields.Count);
  4390. AssertNotNull('Have field',Select.Fields[0]);
  4391. F:=TSQLSelectField(CheckClass(Select.Fields[0],TSQLSelectField));
  4392. AssertNotNull('Have field expresssion,',F.Expression);
  4393. B:=TSQLBinaryExpression(CheckClass(F.Expression,TSQLBinaryExpression));
  4394. P:=TSQLParameterExpression(CheckClass(B.Left,TSQLParameterExpression));
  4395. AssertIdentifierName('Correct parameter name','A',P.Identifier);
  4396. end;
  4397. { TTestRollBackParser }
  4398. function TTestRollBackParser.TestRollback(const ASource: String
  4399. ): TSQLRollbackStatement;
  4400. begin
  4401. CreateParser(ASource);
  4402. FToFree:=Parser.Parse;
  4403. Result:=TSQLRollbackStatement(CheckClass(FToFree,TSQLRollbackStatement));
  4404. FRollback:=Result;
  4405. AssertEquals('End of stream reached',tsqlEOF,Parser.CurrentToken);
  4406. end;
  4407. procedure TTestRollBackParser.TestRollbackError(const ASource: String);
  4408. begin
  4409. FErrSource:=ASource;
  4410. AssertException(ESQLParser,@TestParseError);
  4411. end;
  4412. procedure TTestRollBackParser.TestRollback;
  4413. begin
  4414. TestRollBack('ROLLBACK');
  4415. AssertNull('No transaction name',Rollback.TransactionName);
  4416. AssertEquals('No work',False,Rollback.Work);
  4417. AssertEquals('No release',False,Rollback.Release);
  4418. end;
  4419. procedure TTestRollBackParser.TestRollbackWork;
  4420. begin
  4421. TestRollBack('ROLLBACK WORK');
  4422. AssertNull('No transaction name',Rollback.TransactionName);
  4423. AssertEquals('work',True,Rollback.Work);
  4424. AssertEquals('No release',False,Rollback.Release);
  4425. end;
  4426. procedure TTestRollBackParser.TestRollbackRelease;
  4427. begin
  4428. TestRollBack('ROLLBACK RELEASE');
  4429. AssertNull('No transaction name',Rollback.TransactionName);
  4430. AssertEquals('no work',False,Rollback.Work);
  4431. AssertEquals('release',True,Rollback.Release);
  4432. end;
  4433. procedure TTestRollBackParser.TestRollbackWorkRelease;
  4434. begin
  4435. TestRollBack('ROLLBACK WORK RELEASE');
  4436. AssertNull('No transaction name',Rollback.TransactionName);
  4437. AssertEquals('work',True,Rollback.Work);
  4438. AssertEquals('release',True,Rollback.Release);
  4439. end;
  4440. procedure TTestRollBackParser.TestRollbackTransaction;
  4441. begin
  4442. TestRollBack('ROLLBACK TRANSACTION T');
  4443. AssertIdentifierName('Transaction name','T',Rollback.TransactionName);
  4444. AssertEquals('No work',False,Rollback.Work);
  4445. AssertEquals('No release',False,Rollback.Release);
  4446. end;
  4447. procedure TTestRollBackParser.TestRollbackTransactionWork;
  4448. begin
  4449. TestRollBack('ROLLBACK TRANSACTION T WORK');
  4450. AssertIdentifierName('Transaction name','T',Rollback.TransactionName);
  4451. AssertEquals('work',True,Rollback.Work);
  4452. AssertEquals('No release',False,Rollback.Release);
  4453. end;
  4454. procedure TTestRollBackParser.TestRollbackTransactionRelease;
  4455. begin
  4456. TestRollBack('ROLLBACK TRANSACTION T RELEASE');
  4457. AssertIdentifierName('Transaction name','T',Rollback.TransactionName);
  4458. AssertEquals('no work',False,Rollback.Work);
  4459. AssertEquals('release',True,Rollback.Release);
  4460. end;
  4461. procedure TTestRollBackParser.TestRollbackTransactionWorkRelease;
  4462. begin
  4463. TestRollBack('ROLLBACK TRANSACTION T WORK RELEASE');
  4464. AssertIdentifierName('Transaction name','T',Rollback.TransactionName);
  4465. AssertEquals('work',True,Rollback.Work);
  4466. AssertEquals('release',True,Rollback.Release);
  4467. end;
  4468. { TTestCommitParser }
  4469. function TTestCommitParser.TestCommit(const ASource: String
  4470. ): TSQLCommitStatement;
  4471. begin
  4472. CreateParser(ASource);
  4473. FToFree:=Parser.Parse;
  4474. Result:=TSQLCommitStatement(CheckClass(FToFree,TSQLCommitStatement));
  4475. FCommit:=Result;
  4476. AssertEquals('End of stream reached',tsqlEOF,Parser.CurrentToken);
  4477. end;
  4478. procedure TTestCommitParser.TestCommitError(const ASource: String);
  4479. begin
  4480. FErrSource:=ASource;
  4481. AssertException(ESQLParser,@TestParseError);
  4482. end;
  4483. procedure TTestCommitParser.TestCommit;
  4484. begin
  4485. TestCommit('Commit');
  4486. AssertNull('No transaction name',Commit.TransactionName);
  4487. AssertEquals('No work',False,Commit.Work);
  4488. AssertEquals('No release',False,Commit.Release);
  4489. AssertEquals('No Retain',False,Commit.Retain);
  4490. end;
  4491. procedure TTestCommitParser.TestCommitWork;
  4492. begin
  4493. TestCommit('Commit WORK');
  4494. AssertNull('No transaction name',Commit.TransactionName);
  4495. AssertEquals('work',True,Commit.Work);
  4496. AssertEquals('No release',False,Commit.Release);
  4497. AssertEquals('No Retain',False,Commit.Retain);
  4498. end;
  4499. procedure TTestCommitParser.TestCommitRelease;
  4500. begin
  4501. TestCommit('Commit RELEASE');
  4502. AssertNull('No transaction name',Commit.TransactionName);
  4503. AssertEquals('no work',False,Commit.Work);
  4504. AssertEquals('release',True,Commit.Release);
  4505. AssertEquals('No Retain',False,Commit.Retain);
  4506. end;
  4507. procedure TTestCommitParser.TestCommitWorkRelease;
  4508. begin
  4509. TestCommit('Commit WORK RELEASE');
  4510. AssertNull('No transaction name',Commit.TransactionName);
  4511. AssertEquals('work',True,Commit.Work);
  4512. AssertEquals('release',True,Commit.Release);
  4513. AssertEquals('No Retain',False,Commit.Retain);
  4514. end;
  4515. procedure TTestCommitParser.TestCommitTransaction;
  4516. begin
  4517. TestCommit('Commit TRANSACTION T');
  4518. AssertIdentifierName('Transaction name','T',Commit.TransactionName);
  4519. AssertEquals('No work',False,Commit.Work);
  4520. AssertEquals('No release',False,Commit.Release);
  4521. AssertEquals('No Retain',False,Commit.Retain);
  4522. end;
  4523. procedure TTestCommitParser.TestCommitTransactionWork;
  4524. begin
  4525. TestCommit('Commit WORK TRANSACTION T ');
  4526. AssertIdentifierName('Transaction name','T',Commit.TransactionName);
  4527. AssertEquals('work',True,Commit.Work);
  4528. AssertEquals('No release',False,Commit.Release);
  4529. AssertEquals('No Retain',False,Commit.Retain);
  4530. end;
  4531. procedure TTestCommitParser.TestCommitTransactionRelease;
  4532. begin
  4533. TestCommit('Commit TRANSACTION T RELEASE');
  4534. AssertIdentifierName('Transaction name','T',Commit.TransactionName);
  4535. AssertEquals('no work',False,Commit.Work);
  4536. AssertEquals('release',True,Commit.Release);
  4537. AssertEquals('No Retain',False,Commit.Retain);
  4538. end;
  4539. procedure TTestCommitParser.TestCommitTransactionWorkRelease;
  4540. begin
  4541. TestCommit('Commit WORK TRANSACTION T RELEASE');
  4542. AssertIdentifierName('Transaction name','T',Commit.TransactionName);
  4543. AssertEquals('work',True,Commit.Work);
  4544. AssertEquals('release',True,Commit.Release);
  4545. AssertEquals('No Retain',False,Commit.Retain);
  4546. end;
  4547. procedure TTestCommitParser.TestCommitRetain;
  4548. begin
  4549. TestCommit('Commit RETAIN');
  4550. AssertNull('No transaction name',Commit.TransactionName);
  4551. AssertEquals('No work',False,Commit.Work);
  4552. AssertEquals('No release',False,Commit.Release);
  4553. AssertEquals('Retain',True,Commit.Retain);
  4554. end;
  4555. procedure TTestCommitParser.TestCommitRetainSnapShot;
  4556. begin
  4557. TestCommit('Commit RETAIN SNAPSHOT');
  4558. AssertNull('No transaction name',Commit.TransactionName);
  4559. AssertEquals('No work',False,Commit.Work);
  4560. AssertEquals('No release',False,Commit.Release);
  4561. AssertEquals('Retain',True,Commit.Retain);
  4562. end;
  4563. procedure TTestCommitParser.TestCommitWorkRetain;
  4564. begin
  4565. TestCommit('Commit WORK RETAIN');
  4566. AssertNull('No transaction name',Commit.TransactionName);
  4567. AssertEquals('work',True,Commit.Work);
  4568. AssertEquals('No release',False,Commit.Release);
  4569. AssertEquals('Retain',True,Commit.Retain);
  4570. end;
  4571. procedure TTestCommitParser.TestCommitReleaseRetain;
  4572. begin
  4573. TestCommit('Commit RELEASE RETAIN');
  4574. AssertNull('No transaction name',Commit.TransactionName);
  4575. AssertEquals('no work',False,Commit.Work);
  4576. AssertEquals('release',True,Commit.Release);
  4577. AssertEquals('Retain',True,Commit.Retain);
  4578. end;
  4579. procedure TTestCommitParser.TestCommitWorkReleaseRetain;
  4580. begin
  4581. TestCommit('Commit WORK RELEASE RETAIN');
  4582. AssertNull('No transaction name',Commit.TransactionName);
  4583. AssertEquals('work',True,Commit.Work);
  4584. AssertEquals('release',True,Commit.Release);
  4585. AssertEquals('Retain',True,Commit.Retain);
  4586. end;
  4587. procedure TTestCommitParser.TestCommitTransactionRetain;
  4588. begin
  4589. TestCommit('Commit TRANSACTION T RETAIN');
  4590. AssertIdentifierName('Transaction name','T',Commit.TransactionName);
  4591. AssertEquals('No work',False,Commit.Work);
  4592. AssertEquals('No release',False,Commit.Release);
  4593. AssertEquals('Retain',True,Commit.Retain);
  4594. end;
  4595. procedure TTestCommitParser.TestCommitTransactionWorkRetain;
  4596. begin
  4597. TestCommit('Commit WORK TRANSACTION T RETAIN');
  4598. AssertIdentifierName('Transaction name','T',Commit.TransactionName);
  4599. AssertEquals('work',True,Commit.Work);
  4600. AssertEquals('No release',False,Commit.Release);
  4601. AssertEquals('Retain',True,Commit.Retain);
  4602. end;
  4603. procedure TTestCommitParser.TestCommitTransactionReleaseRetain;
  4604. begin
  4605. TestCommit('Commit TRANSACTION T RELEASE RETAIN');
  4606. AssertIdentifierName('Transaction name','T',Commit.TransactionName);
  4607. AssertEquals('no work',False,Commit.Work);
  4608. AssertEquals('release',True,Commit.Release);
  4609. AssertEquals('Retain',True,Commit.Retain);
  4610. end;
  4611. procedure TTestCommitParser.TestCommitTransactionWorkReleaseRetain;
  4612. begin
  4613. TestCommit('Commit WORK TRANSACTION T RELEASE RETAIN');
  4614. AssertIdentifierName('Transaction name','T',Commit.TransactionName);
  4615. AssertEquals('work',True,Commit.Work);
  4616. AssertEquals('release',True,Commit.Release);
  4617. AssertEquals('Retain',True,Commit.Retain);
  4618. end;
  4619. { TTestExecuteProcedureParser }
  4620. function TTestExecuteProcedureParser.TestExecute(const ASource: String
  4621. ): TSQLExecuteProcedureStatement;
  4622. begin
  4623. CreateParser(ASource);
  4624. FToFree:=Parser.Parse;
  4625. Result:=TSQLExecuteProcedureStatement(CheckClass(FToFree,TSQLExecuteProcedureStatement));
  4626. FExecute:=Result;
  4627. AssertEquals('End of stream reached',tsqlEOF,Parser.CurrentToken);
  4628. end;
  4629. procedure TTestExecuteProcedureParser.TestExecuteError(const ASource: String);
  4630. begin
  4631. FErrSource:=ASource;
  4632. AssertException(ESQLParser,@TestParseError);
  4633. end;
  4634. procedure TTestExecuteProcedureParser.TestExecuteSimple;
  4635. begin
  4636. TestExecute('EXECUTE PROCEDURE A');
  4637. AssertIdentifierName('Correct procedure name','A',Execute.ProcedureName);
  4638. AssertNull('No transaction name',Execute.TransactionName);
  4639. AssertEquals('No arguments',0,Execute.Params.Count);
  4640. AssertEquals('No return values',0,Execute.Returning.Count);
  4641. end;
  4642. procedure TTestExecuteProcedureParser.TestExecuteSimpleTransaction;
  4643. begin
  4644. TestExecute('EXECUTE PROCEDURE TRANSACTION B A');
  4645. AssertIdentifierName('Correct procedure name','A',Execute.ProcedureName);
  4646. AssertIdentifierName('Correct transaction name','B',Execute.TransactionName);
  4647. AssertEquals('No arguments',0,Execute.Params.Count);
  4648. AssertEquals('No return values',0,Execute.Returning.Count);
  4649. end;
  4650. procedure TTestExecuteProcedureParser.TestExecuteSimpleReturningValues;
  4651. begin
  4652. TestExecute('EXECUTE PROCEDURE A RETURNING_VALUES :B');
  4653. AssertIdentifierName('Correct procedure name','A',Execute.ProcedureName);
  4654. AssertNull('No transaction name',Execute.TransactionName);
  4655. AssertEquals('No arguments',0,Execute.Params.Count);
  4656. AssertEquals('1 return value',1,Execute.Returning.Count);
  4657. AssertIdentifierName('return value','B',Execute.Returning[0]);
  4658. end;
  4659. procedure TTestExecuteProcedureParser.TestExecuteSimpleReturning2Values;
  4660. begin
  4661. TestExecute('EXECUTE PROCEDURE A RETURNING_VALUES :B,:C');
  4662. AssertIdentifierName('Correct procedure name','A',Execute.ProcedureName);
  4663. AssertNull('No transaction name',Execute.TransactionName);
  4664. AssertEquals('No arguments',0,Execute.Params.Count);
  4665. AssertEquals('2 return values',2,Execute.Returning.Count);
  4666. AssertIdentifierName('return value','B',Execute.Returning[0]);
  4667. AssertIdentifierName('return value','C',Execute.Returning[1]);
  4668. end;
  4669. procedure TTestExecuteProcedureParser.TestExecuteOneArg;
  4670. Var
  4671. I : TSQLIdentifierExpression;
  4672. begin
  4673. TestExecute('EXECUTE PROCEDURE A (B)');
  4674. AssertIdentifierName('Correct procedure name','A',Execute.ProcedureName);
  4675. AssertNull('No transaction name',Execute.TransactionName);
  4676. AssertEquals('One argument',1,Execute.Params.Count);
  4677. I:=TSQLIdentifierExpression(CheckClass(Execute.Params[0],TSQLIdentifierExpression));
  4678. AssertIdentifierName('Correct argument','B',I.Identifier);
  4679. AssertEquals('No return values',0,Execute.Returning.Count);
  4680. end;
  4681. procedure TTestExecuteProcedureParser.TestExecuteOneArgNB;
  4682. Var
  4683. I : TSQLIdentifierExpression;
  4684. begin
  4685. TestExecute('EXECUTE PROCEDURE A B');
  4686. AssertIdentifierName('Correct procedure name','A',Execute.ProcedureName);
  4687. AssertNull('No transaction name',Execute.TransactionName);
  4688. AssertEquals('One argument',1,Execute.Params.Count);
  4689. I:=TSQLIdentifierExpression(CheckClass(Execute.Params[0],TSQLIdentifierExpression));
  4690. AssertIdentifierName('Correct argument','B',I.Identifier);
  4691. AssertEquals('No return values',0,Execute.Returning.Count);
  4692. end;
  4693. procedure TTestExecuteProcedureParser.TestExecuteTwoArgs;
  4694. Var
  4695. I : TSQLIdentifierExpression;
  4696. begin
  4697. TestExecute('EXECUTE PROCEDURE A (B,C)');
  4698. AssertIdentifierName('Correct procedure name','A',Execute.ProcedureName);
  4699. AssertNull('No transaction name',Execute.TransactionName);
  4700. AssertEquals('Two arguments',2,Execute.Params.Count);
  4701. I:=TSQLIdentifierExpression(CheckClass(Execute.Params[0],TSQLIdentifierExpression));
  4702. AssertIdentifierName('Correct argument','B',I.Identifier);
  4703. I:=TSQLIdentifierExpression(CheckClass(Execute.Params[1],TSQLIdentifierExpression));
  4704. AssertIdentifierName('Correct argument','C',I.Identifier);
  4705. AssertEquals('No return values',0,Execute.Returning.Count);
  4706. end;
  4707. procedure TTestExecuteProcedureParser.TestExecuteTwoArgsNB;
  4708. Var
  4709. I : TSQLIdentifierExpression;
  4710. begin
  4711. TestExecute('EXECUTE PROCEDURE A B, C');
  4712. AssertIdentifierName('Correct procedure name','A',Execute.ProcedureName);
  4713. AssertNull('No transaction name',Execute.TransactionName);
  4714. AssertEquals('Two arguments',2,Execute.Params.Count);
  4715. I:=TSQLIdentifierExpression(CheckClass(Execute.Params[0],TSQLIdentifierExpression));
  4716. AssertIdentifierName('Correct argument','B',I.Identifier);
  4717. I:=TSQLIdentifierExpression(CheckClass(Execute.Params[1],TSQLIdentifierExpression));
  4718. AssertIdentifierName('Correct argument','C',I.Identifier);
  4719. AssertEquals('No return values',0,Execute.Returning.Count);
  4720. end;
  4721. procedure TTestExecuteProcedureParser.TestExecuteOneArgSelect;
  4722. Var
  4723. S : TSQLSelectExpression;
  4724. begin
  4725. TestExecute('EXECUTE PROCEDURE A ((SELECT B FROM C))');
  4726. AssertIdentifierName('Correct procedure name','A',Execute.ProcedureName);
  4727. AssertNull('No transaction name',Execute.TransactionName);
  4728. AssertEquals('One argument',1,Execute.Params.Count);
  4729. S:=TSQLSelectExpression(CheckClass(Execute.Params[0],TSQLSelectExpression));
  4730. AssertField(S.Select.Fields[0],'B','');
  4731. AssertTable(S.Select.Tables[0],'C','');
  4732. AssertEquals('No return values',0,Execute.Returning.Count);
  4733. end;
  4734. procedure TTestExecuteProcedureParser.TestExecuteOneArgSelectNB;
  4735. Var
  4736. S : TSQLSelectExpression;
  4737. begin
  4738. TestExecute('EXECUTE PROCEDURE A (SELECT B FROM C)');
  4739. AssertIdentifierName('Correct procedure name','A',Execute.ProcedureName);
  4740. AssertNull('No transaction name',Execute.TransactionName);
  4741. AssertEquals('One argument',1,Execute.Params.Count);
  4742. S:=TSQLSelectExpression(CheckClass(Execute.Params[0],TSQLSelectExpression));
  4743. AssertField(S.Select.Fields[0],'B','');
  4744. AssertTable(S.Select.Tables[0],'C','');
  4745. AssertEquals('No return values',0,Execute.Returning.Count);
  4746. end;
  4747. procedure TTestExecuteProcedureParser.TestExecuteTwoArgsSelect;
  4748. Var
  4749. S : TSQLSelectExpression;
  4750. I : TSQLIdentifierExpression;
  4751. begin
  4752. TestExecute('EXECUTE PROCEDURE A ((SELECT B FROM C),D)');
  4753. AssertIdentifierName('Correct procedure name','A',Execute.ProcedureName);
  4754. AssertNull('No transaction name',Execute.TransactionName);
  4755. AssertEquals('Two arguments',2,Execute.Params.Count);
  4756. S:=TSQLSelectExpression(CheckClass(Execute.Params[0],TSQLSelectExpression));
  4757. AssertField(S.Select.Fields[0],'B','');
  4758. AssertTable(S.Select.Tables[0],'C','');
  4759. I:=TSQLIdentifierExpression(CheckClass(Execute.Params[1],TSQLIdentifierExpression));
  4760. AssertIdentifierName('Correct argument','D',I.Identifier);
  4761. AssertEquals('No return values',0,Execute.Returning.Count);
  4762. end;
  4763. procedure TTestExecuteProcedureParser.TestExecuteTwoArgsSelectNB;
  4764. Var
  4765. S : TSQLSelectExpression;
  4766. I : TSQLIdentifierExpression;
  4767. begin
  4768. TestExecute('EXECUTE PROCEDURE A (SELECT B FROM C),D');
  4769. AssertIdentifierName('Correct procedure name','A',Execute.ProcedureName);
  4770. AssertNull('No transaction name',Execute.TransactionName);
  4771. AssertEquals('Two arguments',2,Execute.Params.Count);
  4772. S:=TSQLSelectExpression(CheckClass(Execute.Params[0],TSQLSelectExpression));
  4773. AssertField(S.Select.Fields[0],'B','');
  4774. AssertTable(S.Select.Tables[0],'C','');
  4775. I:=TSQLIdentifierExpression(CheckClass(Execute.Params[1],TSQLIdentifierExpression));
  4776. AssertIdentifierName('Correct argument','D',I.Identifier);
  4777. AssertEquals('No return values',0,Execute.Returning.Count);
  4778. end;
  4779. procedure TTestExecuteProcedureParser.TestExecuteOneArgSelectErr;
  4780. begin
  4781. TestExecuteError('EXECUTE PROCEDURE A ((SELECT B FROM C), 2')
  4782. end;
  4783. procedure TTestExecuteProcedureParser.TestExecuteOneArgSelectErr2;
  4784. begin
  4785. TestExecuteError('EXECUTE PROCEDURE A (SELECT B FROM C), 2)')
  4786. end;
  4787. procedure TTestExecuteProcedureParser.TestExecuteOneArgSelectErr3;
  4788. begin
  4789. TestExecuteError('EXECUTE PROCEDURE A B)')
  4790. end;
  4791. procedure TTestExecuteProcedureParser.TestExecuteOneArgSelectErr4;
  4792. begin
  4793. TestExecuteError('EXECUTE PROCEDURE A B,C)')
  4794. end;
  4795. { EXECUTE PROCEDURE DELETE_EMPLOYEE2 1, 2;
  4796. EXECUTE PROCEDURE DELETE_EMPLOYEE2 (1, 2);
  4797. EXECUTE PROCEDURE DELETE_EMPLOYEE2 ((SELECT A FROM A), 2);
  4798. EXECUTE PROCEDURE DELETE_EMPLOYEE2 (SELECT A FROM A), 2;
  4799. }
  4800. { TTestConnectParser }
  4801. function TTestConnectParser.TestConnect(const ASource: String
  4802. ): TSQLConnectStatement;
  4803. begin
  4804. CreateParser(ASource);
  4805. FToFree:=Parser.Parse;
  4806. Result:=TSQLConnectStatement(CheckClass(FToFree,TSQLConnectStatement));
  4807. FConnect:=Result;
  4808. AssertEquals('End of stream reached',tsqlEOF,Parser.CurrentToken);
  4809. end;
  4810. procedure TTestConnectParser.TestConnectError(const ASource: String);
  4811. begin
  4812. FErrSource:=ASource;
  4813. AssertException(ESQLParser,@TestParseError);
  4814. end;
  4815. procedure TTestConnectParser.TestConnectSimple;
  4816. begin
  4817. TestConnect('CONNECT ''/my/database/file''');
  4818. AssertEquals('Database name','/my/database/file',Connect.DatabaseName);
  4819. AssertEquals('User name','',Connect.UserName);
  4820. AssertEquals('Password','',Connect.Password);
  4821. AssertEquals('Role','',Connect.Role);
  4822. AssertEquals('Cache',0,Connect.Cache);
  4823. end;
  4824. procedure TTestConnectParser.TestConnectUser;
  4825. begin
  4826. TestConnect('CONNECT ''/my/database/file'' USER ''me''');
  4827. AssertEquals('Database name','/my/database/file',Connect.DatabaseName);
  4828. AssertEquals('User name','me',Connect.UserName);
  4829. AssertEquals('Password','',Connect.Password);
  4830. AssertEquals('Role','',Connect.Role);
  4831. AssertEquals('Cache',0,Connect.Cache);
  4832. end;
  4833. procedure TTestConnectParser.TestConnectPassword;
  4834. begin
  4835. TestConnect('CONNECT ''/my/database/file'' PASSWORD ''secret''');
  4836. AssertEquals('Database name','/my/database/file',Connect.DatabaseName);
  4837. AssertEquals('User name','',Connect.UserName);
  4838. AssertEquals('Password','secret',Connect.Password);
  4839. AssertEquals('Role','',Connect.Role);
  4840. AssertEquals('Cache',0,Connect.Cache);
  4841. end;
  4842. procedure TTestConnectParser.TestConnectUserPassword;
  4843. begin
  4844. TestConnect('CONNECT ''/my/database/file'' USER ''me'' PASSWORD ''secret''');
  4845. AssertEquals('Database name','/my/database/file',Connect.DatabaseName);
  4846. AssertEquals('User name','me',Connect.UserName);
  4847. AssertEquals('Password','secret',Connect.Password);
  4848. AssertEquals('Role','',Connect.Role);
  4849. AssertEquals('Cache',0,Connect.Cache);
  4850. end;
  4851. procedure TTestConnectParser.TestConnectUserPasswordRole;
  4852. begin
  4853. TestConnect('CONNECT ''/my/database/file'' USER ''me'' PASSWORD ''secret'' ROLE ''admin''');
  4854. AssertEquals('Database name','/my/database/file',Connect.DatabaseName);
  4855. AssertEquals('User name','me',Connect.UserName);
  4856. AssertEquals('Password','secret',Connect.Password);
  4857. AssertEquals('Role','admin',Connect.Role);
  4858. AssertEquals('Cache',0,Connect.Cache);
  4859. end;
  4860. procedure TTestConnectParser.TestConnectUserPasswordRoleCache;
  4861. begin
  4862. TestConnect('CONNECT ''/my/database/file'' USER ''me'' PASSWORD ''secret'' ROLE ''admin'' CACHE 2048');
  4863. AssertEquals('Database name','/my/database/file',Connect.DatabaseName);
  4864. AssertEquals('User name','me',Connect.UserName);
  4865. AssertEquals('Password','secret',Connect.Password);
  4866. AssertEquals('Role','admin',Connect.Role);
  4867. AssertEquals('Cache',2048,Connect.Cache);
  4868. end;
  4869. procedure TTestConnectParser.TestConnectSimpleCache;
  4870. begin
  4871. TestConnect('CONNECT ''/my/database/file'' CACHE 2048');
  4872. AssertEquals('Database name','/my/database/file',Connect.DatabaseName);
  4873. AssertEquals('User name','',Connect.UserName);
  4874. AssertEquals('Password','',Connect.Password);
  4875. AssertEquals('Role','',Connect.Role);
  4876. AssertEquals('Cache',2048,Connect.Cache);
  4877. end;
  4878. { TTestCreateDatabaseParser }
  4879. function TTestCreateDatabaseParser.TestCreate(const ASource: String
  4880. ): TSQLCreateDatabaseStatement;
  4881. begin
  4882. CreateParser(ASource);
  4883. FToFree:=Parser.Parse;
  4884. Result:=TSQLCreateDatabaseStatement(CheckClass(FToFree,TSQLCreateDatabaseStatement));
  4885. FCreateDB:=Result;
  4886. AssertEquals('End of stream reached',tsqlEOF,Parser.CurrentToken);
  4887. end;
  4888. procedure TTestCreateDatabaseParser.TestCreateError(const ASource: String);
  4889. begin
  4890. FerrSource:=ASource;
  4891. AssertException(ESQLParser,@TestParseError);
  4892. end;
  4893. procedure TTestCreateDatabaseParser.TestSimple;
  4894. begin
  4895. TestCreate('CREATE DATABASE ''/my/database/file''');
  4896. AssertEquals('Not schema',False,CreateDB.UseSchema);
  4897. AssertEquals('Database file','/my/database/file',CreateDB.FileName);
  4898. AssertEquals('Username','',CreateDB.UserName);
  4899. AssertEquals('Password','',CreateDB.Password);
  4900. AssertNull('Character set',CreateDB.CharSet);
  4901. AssertEquals('Page size',0,CreateDB.PageSize);
  4902. AssertEquals('Length',0,CreateDB.Length);
  4903. AssertEquals('Secondary files',0,CreateDB.SecondaryFiles.Count);
  4904. end;
  4905. procedure TTestCreateDatabaseParser.TestSimpleSchema;
  4906. begin
  4907. TestCreate('CREATE SCHEMA ''/my/database/file''');
  4908. AssertEquals('schema',True,CreateDB.UseSchema);
  4909. AssertEquals('Database file','/my/database/file',CreateDB.FileName);
  4910. AssertEquals('Username','',CreateDB.UserName);
  4911. AssertEquals('Password','',CreateDB.Password);
  4912. AssertNull('Character set',CreateDB.CharSet);
  4913. AssertEquals('Page size',0,CreateDB.PageSize);
  4914. AssertEquals('Length',0,CreateDB.Length);
  4915. AssertEquals('Secondary files',0,CreateDB.SecondaryFiles.Count);
  4916. end;
  4917. procedure TTestCreateDatabaseParser.TestSimpleUSer;
  4918. begin
  4919. TestCreate('CREATE DATABASE ''/my/database/file'' USER ''me''');
  4920. AssertEquals('Not schema',False,CreateDB.UseSchema);
  4921. AssertEquals('Database file','/my/database/file',CreateDB.FileName);
  4922. AssertEquals('Username','me',CreateDB.UserName);
  4923. AssertEquals('Password','',CreateDB.Password);
  4924. AssertNull('Character set',CreateDB.CharSet);
  4925. AssertEquals('Page size',0,CreateDB.PageSize);
  4926. AssertEquals('Length',0,CreateDB.Length);
  4927. AssertEquals('Secondary files',0,CreateDB.SecondaryFiles.Count);
  4928. end;
  4929. procedure TTestCreateDatabaseParser.TestSimpleUSerPassword;
  4930. begin
  4931. TestCreate('CREATE DATABASE ''/my/database/file'' USER ''me'' PASSWORD ''SECRET''');
  4932. AssertEquals('Not schema',False,CreateDB.UseSchema);
  4933. AssertEquals('Database file','/my/database/file',CreateDB.FileName);
  4934. AssertEquals('Username','me',CreateDB.UserName);
  4935. AssertEquals('Password','SECRET',CreateDB.Password);
  4936. AssertNull('Character set',CreateDB.CharSet);
  4937. AssertEquals('Page size',0,CreateDB.PageSize);
  4938. AssertEquals('Length',0,CreateDB.Length);
  4939. AssertEquals('Secondary files',0,CreateDB.SecondaryFiles.Count);
  4940. end;
  4941. procedure TTestCreateDatabaseParser.TestSimplePassword;
  4942. begin
  4943. TestCreate('CREATE DATABASE ''/my/database/file'' PASSWORD ''SECRET''');
  4944. AssertEquals('Not schema',False,CreateDB.UseSchema);
  4945. AssertEquals('Database file','/my/database/file',CreateDB.FileName);
  4946. AssertEquals('Username','',CreateDB.UserName);
  4947. AssertEquals('Password','SECRET',CreateDB.Password);
  4948. AssertNull('Character set',CreateDB.CharSet);
  4949. AssertEquals('Page size',0,CreateDB.PageSize);
  4950. AssertEquals('Length',0,CreateDB.Length);
  4951. AssertEquals('Secondary files',0,CreateDB.SecondaryFiles.Count);
  4952. end;
  4953. procedure TTestCreateDatabaseParser.TestPageSize;
  4954. begin
  4955. TestCreate('CREATE DATABASE ''/my/database/file'' PAGE_SIZE = 2048');
  4956. AssertEquals('Not schema',False,CreateDB.UseSchema);
  4957. AssertEquals('Database file','/my/database/file',CreateDB.FileName);
  4958. AssertEquals('Username','',CreateDB.UserName);
  4959. AssertEquals('Password','',CreateDB.Password);
  4960. AssertNull('Character set',CreateDB.CharSet);
  4961. AssertEquals('Page size',2048,CreateDB.PageSize);
  4962. AssertEquals('Length',0,CreateDB.Length);
  4963. AssertEquals('Secondary files',0,CreateDB.SecondaryFiles.Count);
  4964. end;
  4965. procedure TTestCreateDatabaseParser.TestPageSize2;
  4966. begin
  4967. TestCreate('CREATE DATABASE ''/my/database/file'' PAGE_SIZE 2048');
  4968. AssertEquals('Not schema',False,CreateDB.UseSchema);
  4969. AssertEquals('Database file','/my/database/file',CreateDB.FileName);
  4970. AssertEquals('Username','',CreateDB.UserName);
  4971. AssertEquals('Password','',CreateDB.Password);
  4972. AssertNull('Character set',CreateDB.CharSet);
  4973. AssertEquals('Page size',2048,CreateDB.PageSize);
  4974. AssertEquals('Length',0,CreateDB.Length);
  4975. AssertEquals('Secondary files',0,CreateDB.SecondaryFiles.Count);
  4976. end;
  4977. procedure TTestCreateDatabaseParser.TestPageSizeLength;
  4978. begin
  4979. TestCreate('CREATE DATABASE ''/my/database/file'' PAGE_SIZE 2048 LENGTH = 2000');
  4980. AssertEquals('Not schema',False,CreateDB.UseSchema);
  4981. AssertEquals('Database file','/my/database/file',CreateDB.FileName);
  4982. AssertEquals('Username','',CreateDB.UserName);
  4983. AssertEquals('Password','',CreateDB.Password);
  4984. AssertNull('Character set',CreateDB.CharSet);
  4985. AssertEquals('Page size',2048,CreateDB.PageSize);
  4986. AssertEquals('Length',2000,CreateDB.Length);
  4987. AssertEquals('Secondary files',0,CreateDB.SecondaryFiles.Count);
  4988. end;
  4989. procedure TTestCreateDatabaseParser.TestPageSizeLength2;
  4990. begin
  4991. TestCreate('CREATE DATABASE ''/my/database/file'' PAGE_SIZE 2048 LENGTH 2000');
  4992. AssertEquals('Not schema',False,CreateDB.UseSchema);
  4993. AssertEquals('Database file','/my/database/file',CreateDB.FileName);
  4994. AssertEquals('Username','',CreateDB.UserName);
  4995. AssertEquals('Password','',CreateDB.Password);
  4996. AssertNull('Character set',CreateDB.CharSet);
  4997. AssertEquals('Page size',2048,CreateDB.PageSize);
  4998. AssertEquals('Length',2000,CreateDB.Length);
  4999. AssertEquals('Secondary files',0,CreateDB.SecondaryFiles.Count);
  5000. end;
  5001. procedure TTestCreateDatabaseParser.TestPageSizeLength3;
  5002. begin
  5003. TestCreate('CREATE DATABASE ''/my/database/file'' PAGE_SIZE 2048 LENGTH 2000 PAGES');
  5004. AssertEquals('Not schema',False,CreateDB.UseSchema);
  5005. AssertEquals('Database file','/my/database/file',CreateDB.FileName);
  5006. AssertEquals('Username','',CreateDB.UserName);
  5007. AssertEquals('Password','',CreateDB.Password);
  5008. AssertNull('Character set',CreateDB.CharSet);
  5009. AssertEquals('Page size',2048,CreateDB.PageSize);
  5010. AssertEquals('Length',2000,CreateDB.Length);
  5011. AssertEquals('Secondary files',0,CreateDB.SecondaryFiles.Count);
  5012. end;
  5013. procedure TTestCreateDatabaseParser.TestPageSizeLength4;
  5014. begin
  5015. TestCreate('CREATE DATABASE ''/my/database/file'' PAGE_SIZE 2048 LENGTH 2000 PAGE');
  5016. AssertEquals('Not schema',False,CreateDB.UseSchema);
  5017. AssertEquals('Database file','/my/database/file',CreateDB.FileName);
  5018. AssertEquals('Username','',CreateDB.UserName);
  5019. AssertEquals('Password','',CreateDB.Password);
  5020. AssertNull('Character set',CreateDB.CharSet);
  5021. AssertEquals('Page size',2048,CreateDB.PageSize);
  5022. AssertEquals('Length',2000,CreateDB.Length);
  5023. AssertEquals('Secondary files',0,CreateDB.SecondaryFiles.Count);
  5024. end;
  5025. procedure TTestCreateDatabaseParser.TestCharset;
  5026. begin
  5027. TestCreate('CREATE DATABASE ''/my/database/file'' DEFAULT CHARACTER SET UTF8');
  5028. AssertEquals('Not schema',False,CreateDB.UseSchema);
  5029. AssertEquals('Database file','/my/database/file',CreateDB.FileName);
  5030. AssertEquals('Username','',CreateDB.UserName);
  5031. AssertEquals('Password','',CreateDB.Password);
  5032. AssertIDentifierName('Character set','UTF8',CreateDB.CharSet);
  5033. AssertEquals('Page size',0,CreateDB.PageSize);
  5034. AssertEquals('Length',0,CreateDB.Length);
  5035. AssertEquals('Secondary files',0,CreateDB.SecondaryFiles.Count);
  5036. end;
  5037. procedure TTestCreateDatabaseParser.TestSecondaryFile1;
  5038. begin
  5039. TestCreate('CREATE DATABASE ''/my/database/file'' PAGE_SIZE 2048 LENGTH 2000 FILE ''/my/database/file2''');
  5040. AssertEquals('Not schema',False,CreateDB.UseSchema);
  5041. AssertEquals('Database file','/my/database/file',CreateDB.FileName);
  5042. AssertEquals('Username','',CreateDB.UserName);
  5043. AssertEquals('Password','',CreateDB.Password);
  5044. AssertNull('Character set',CreateDB.CharSet);
  5045. AssertEquals('Page size',2048,CreateDB.PageSize);
  5046. AssertEquals('Length',2000,CreateDB.Length);
  5047. AssertEquals('Secondary files',1,CreateDB.SecondaryFiles.Count);
  5048. AssertSecondaryFile(CreateDB.SecondaryFiles[0],'/my/database/file2',0,0);
  5049. end;
  5050. procedure TTestCreateDatabaseParser.TestSecondaryFile2;
  5051. begin
  5052. TestCreate('CREATE DATABASE ''/my/database/file'' PAGE_SIZE 2048 LENGTH 2000 FILE ''/my/database/file2'' LENGTH 1000');
  5053. AssertEquals('Not schema',False,CreateDB.UseSchema);
  5054. AssertEquals('Database file','/my/database/file',CreateDB.FileName);
  5055. AssertEquals('Username','',CreateDB.UserName);
  5056. AssertEquals('Password','',CreateDB.Password);
  5057. AssertNull('Character set',CreateDB.CharSet);
  5058. AssertEquals('Page size',2048,CreateDB.PageSize);
  5059. AssertEquals('Length',2000,CreateDB.Length);
  5060. AssertEquals('Secondary files',1,CreateDB.SecondaryFiles.Count);
  5061. AssertSecondaryFile(CreateDB.SecondaryFiles[0],'/my/database/file2',1000,0);
  5062. end;
  5063. procedure TTestCreateDatabaseParser.TestSecondaryFile3;
  5064. begin
  5065. TestCreate('CREATE DATABASE ''/my/database/file'' PAGE_SIZE 2048 LENGTH 2000 FILE ''/my/database/file2'' LENGTH = 1000');
  5066. AssertEquals('Not schema',False,CreateDB.UseSchema);
  5067. AssertEquals('Database file','/my/database/file',CreateDB.FileName);
  5068. AssertEquals('Username','',CreateDB.UserName);
  5069. AssertEquals('Password','',CreateDB.Password);
  5070. AssertNull('Character set',CreateDB.CharSet);
  5071. AssertEquals('Page size',2048,CreateDB.PageSize);
  5072. AssertEquals('Length',2000,CreateDB.Length);
  5073. AssertEquals('Secondary files',1,CreateDB.SecondaryFiles.Count);
  5074. AssertSecondaryFile(CreateDB.SecondaryFiles[0],'/my/database/file2',1000,0);
  5075. end;
  5076. procedure TTestCreateDatabaseParser.TestSecondaryFile4;
  5077. begin
  5078. TestCreate('CREATE DATABASE ''/my/database/file'' PAGE_SIZE 2048 LENGTH 2000 FILE ''/my/database/file2'' LENGTH = 1000 PAGE');
  5079. AssertEquals('Not schema',False,CreateDB.UseSchema);
  5080. AssertEquals('Database file','/my/database/file',CreateDB.FileName);
  5081. AssertEquals('Username','',CreateDB.UserName);
  5082. AssertEquals('Password','',CreateDB.Password);
  5083. AssertNull('Character set',CreateDB.CharSet);
  5084. AssertEquals('Page size',2048,CreateDB.PageSize);
  5085. AssertEquals('Length',2000,CreateDB.Length);
  5086. AssertEquals('Secondary files',1,CreateDB.SecondaryFiles.Count);
  5087. AssertSecondaryFile(CreateDB.SecondaryFiles[0],'/my/database/file2',1000,0);
  5088. end;
  5089. procedure TTestCreateDatabaseParser.TestSecondaryFile5;
  5090. begin
  5091. TestCreate('CREATE DATABASE ''/my/database/file'' PAGE_SIZE 2048 LENGTH 2000 FILE ''/my/database/file2'' LENGTH = 1000 PAGES');
  5092. AssertEquals('Not schema',False,CreateDB.UseSchema);
  5093. AssertEquals('Database file','/my/database/file',CreateDB.FileName);
  5094. AssertEquals('Username','',CreateDB.UserName);
  5095. AssertEquals('Password','',CreateDB.Password);
  5096. AssertNull('Character set',CreateDB.CharSet);
  5097. AssertEquals('Page size',2048,CreateDB.PageSize);
  5098. AssertEquals('Length',2000,CreateDB.Length);
  5099. AssertEquals('Secondary files',1,CreateDB.SecondaryFiles.Count);
  5100. AssertSecondaryFile(CreateDB.SecondaryFiles[0],'/my/database/file2',1000,0);
  5101. end;
  5102. procedure TTestCreateDatabaseParser.TestSecondaryFile6;
  5103. begin
  5104. TestCreate('CREATE DATABASE ''/my/database/file'' PAGE_SIZE 2048 LENGTH 2000 FILE ''/my/database/file2'' STARTING 3000 ');
  5105. AssertEquals('Not schema',False,CreateDB.UseSchema);
  5106. AssertEquals('Database file','/my/database/file',CreateDB.FileName);
  5107. AssertEquals('Username','',CreateDB.UserName);
  5108. AssertEquals('Password','',CreateDB.Password);
  5109. AssertNull('Character set',CreateDB.CharSet);
  5110. AssertEquals('Page size',2048,CreateDB.PageSize);
  5111. AssertEquals('Length',2000,CreateDB.Length);
  5112. AssertEquals('Secondary files',1,CreateDB.SecondaryFiles.Count);
  5113. AssertSecondaryFile(CreateDB.SecondaryFiles[0],'/my/database/file2',0,3000);
  5114. end;
  5115. procedure TTestCreateDatabaseParser.TestSecondaryFile7;
  5116. begin
  5117. TestCreate('CREATE DATABASE ''/my/database/file'' PAGE_SIZE 2048 LENGTH 2000 FILE ''/my/database/file2'' STARTING AT 3000 ');
  5118. AssertEquals('Not schema',False,CreateDB.UseSchema);
  5119. AssertEquals('Database file','/my/database/file',CreateDB.FileName);
  5120. AssertEquals('Username','',CreateDB.UserName);
  5121. AssertEquals('Password','',CreateDB.Password);
  5122. AssertNull('Character set',CreateDB.CharSet);
  5123. AssertEquals('Page size',2048,CreateDB.PageSize);
  5124. AssertEquals('Length',2000,CreateDB.Length);
  5125. AssertEquals('Secondary files',1,CreateDB.SecondaryFiles.Count);
  5126. AssertSecondaryFile(CreateDB.SecondaryFiles[0],'/my/database/file2',0,3000);
  5127. end;
  5128. procedure TTestCreateDatabaseParser.TestSecondaryFile9;
  5129. begin
  5130. TestCreate('CREATE DATABASE ''/my/database/file'' PAGE_SIZE 2048 LENGTH 2000 FILE ''/my/database/file2'' LENGTH 201 STARTING AT PAGE 3000 ');
  5131. AssertEquals('Not schema',False,CreateDB.UseSchema);
  5132. AssertEquals('Database file','/my/database/file',CreateDB.FileName);
  5133. AssertEquals('Username','',CreateDB.UserName);
  5134. AssertEquals('Password','',CreateDB.Password);
  5135. AssertNull('Character set',CreateDB.CharSet);
  5136. AssertEquals('Page size',2048,CreateDB.PageSize);
  5137. AssertEquals('Length',2000,CreateDB.Length);
  5138. AssertEquals('Secondary files',1,CreateDB.SecondaryFiles.Count);
  5139. AssertSecondaryFile(CreateDB.SecondaryFiles[0],'/my/database/file2',201,3000);
  5140. end;
  5141. procedure TTestCreateDatabaseParser.TestSecondaryFile10;
  5142. begin
  5143. TestCreate('CREATE DATABASE ''/my/database/file'' PAGE_SIZE 2048 LENGTH 2000 FILE ''/my/database/file2'' STARTING AT PAGE 3000 LENGTH 201');
  5144. AssertEquals('Not schema',False,CreateDB.UseSchema);
  5145. AssertEquals('Database file','/my/database/file',CreateDB.FileName);
  5146. AssertEquals('Username','',CreateDB.UserName);
  5147. AssertEquals('Password','',CreateDB.Password);
  5148. AssertNull('Character set',CreateDB.CharSet);
  5149. AssertEquals('Page size',2048,CreateDB.PageSize);
  5150. AssertEquals('Length',2000,CreateDB.Length);
  5151. AssertEquals('Secondary files',1,CreateDB.SecondaryFiles.Count);
  5152. AssertSecondaryFile(CreateDB.SecondaryFiles[0],'/my/database/file2',201,3000);
  5153. end;
  5154. procedure TTestCreateDatabaseParser.TestSecondaryFile8;
  5155. begin
  5156. TestCreate('CREATE DATABASE ''/my/database/file'' PAGE_SIZE 2048 LENGTH 2000 FILE ''/my/database/file2'' STARTING AT PAGE 3000 ');
  5157. AssertEquals('Not schema',False,CreateDB.UseSchema);
  5158. AssertEquals('Database file','/my/database/file',CreateDB.FileName);
  5159. AssertEquals('Username','',CreateDB.UserName);
  5160. AssertEquals('Password','',CreateDB.Password);
  5161. AssertNull('Character set',CreateDB.CharSet);
  5162. AssertEquals('Page size',2048,CreateDB.PageSize);
  5163. AssertEquals('Length',2000,CreateDB.Length);
  5164. AssertEquals('Secondary files',1,CreateDB.SecondaryFiles.Count);
  5165. AssertSecondaryFile(CreateDB.SecondaryFiles[0],'/my/database/file2',0,3000);
  5166. end;
  5167. procedure TTestCreateDatabaseParser.TestSecondaryFileS;
  5168. begin
  5169. TestCreate('CREATE DATABASE ''/my/database/file'' PAGE_SIZE 2048 LENGTH 2000 FILE ''/my/database/file2'' FILE ''/my/database/file3'' ');
  5170. AssertEquals('Not schema',False,CreateDB.UseSchema);
  5171. AssertEquals('Database file','/my/database/file',CreateDB.FileName);
  5172. AssertEquals('Username','',CreateDB.UserName);
  5173. AssertEquals('Password','',CreateDB.Password);
  5174. AssertNull('Character set',CreateDB.CharSet);
  5175. AssertEquals('Page size',2048,CreateDB.PageSize);
  5176. AssertEquals('Length',2000,CreateDB.Length);
  5177. AssertEquals('Secondary files',2,CreateDB.SecondaryFiles.Count);
  5178. AssertSecondaryFile(CreateDB.SecondaryFiles[0],'/my/database/file2',0,0);
  5179. AssertSecondaryFile(CreateDB.SecondaryFiles[1],'/my/database/file3',0,0);
  5180. end;
  5181. procedure TTestCreateDatabaseParser.TestSecondaryFileError1;
  5182. begin
  5183. TestCreateError('CREATE DATABASE ''/my/database/file'' PAGE_SIZE 2048 LENGTH 2000 FILE ''/my/database/file2'' LENGTH 3 LENGTH 2');
  5184. end;
  5185. procedure TTestCreateDatabaseParser.TestSecondaryFileError2;
  5186. begin
  5187. TestCreateError('CREATE DATABASE ''/my/database/file'' PAGE_SIZE 2048 LENGTH 2000 FILE ''/my/database/file2'' STARTING 3 STARTING 2');
  5188. end;
  5189. procedure TTestCreateDatabaseParser.TestSecondaryFileError3;
  5190. begin
  5191. TestCreateError('CREATE DATABASE ''/my/database/file'' PAGE_SIZE 2048 LENGTH 2000 FILE ''/my/database/file2'' STARTING 3 LENGTH 2 STARTING 2');
  5192. end;
  5193. { TTestAlterDatabaseParser }
  5194. function TTestAlterDatabaseParser.TestAlter(const ASource: String
  5195. ): TSQLAlterDatabaseStatement;
  5196. begin
  5197. CreateParser(ASource);
  5198. FToFree:=Parser.Parse;
  5199. Result:=TSQLAlterDatabaseStatement(CheckClass(FToFree,TSQLAlterDatabaseStatement));
  5200. FAlterDB:=Result;
  5201. AssertEquals('End of stream reached',tsqlEOF,Parser.CurrentToken);
  5202. end;
  5203. procedure TTestAlterDatabaseParser.TestAlterError(const ASource: String);
  5204. begin
  5205. FerrSource:=ASource;
  5206. AssertException(ESQLParser,@TestParseError);
  5207. end;
  5208. procedure TTestAlterDatabaseParser.TestSimple;
  5209. begin
  5210. TestAlter('ALTER DATABASE ADD FILE ''/my/file''');
  5211. AssertEquals('Operation count',1,AlterDB.Operations.Count);
  5212. AssertSecondaryFile(AlterDB.Operations[0],'/my/file',0,0);
  5213. end;
  5214. procedure TTestAlterDatabaseParser.TestStarting;
  5215. begin
  5216. TestAlter('ALTER DATABASE ADD FILE ''/my/file'' STARTING AT 100');
  5217. AssertEquals('Operation count',1,AlterDB.Operations.Count);
  5218. AssertSecondaryFile(AlterDB.Operations[0],'/my/file',0,100);
  5219. end;
  5220. procedure TTestAlterDatabaseParser.TestStartingLength;
  5221. begin
  5222. TestAlter('ALTER DATABASE ADD FILE ''/my/file'' STARTING AT 100 LENGTH 200');
  5223. AssertEquals('Operation count',1,AlterDB.Operations.Count);
  5224. AssertSecondaryFile(AlterDB.Operations[0],'/my/file',200,100);
  5225. end;
  5226. procedure TTestAlterDatabaseParser.TestFiles;
  5227. begin
  5228. TestAlter('ALTER DATABASE ADD FILE ''/my/file2'' ADD FILE ''/my/file3'' ');
  5229. AssertEquals('Operation count',2,AlterDB.Operations.Count);
  5230. AssertSecondaryFile(AlterDB.Operations[0],'/my/file2',0,0);
  5231. AssertSecondaryFile(AlterDB.Operations[1],'/my/file3',0,0);
  5232. end;
  5233. procedure TTestAlterDatabaseParser.TestFiles2;
  5234. begin
  5235. TestAlter('ALTER DATABASE ADD FILE ''/my/file2'' FILE ''/my/file3'' ');
  5236. AssertEquals('Operation count',2,AlterDB.Operations.Count);
  5237. AssertSecondaryFile(AlterDB.Operations[0],'/my/file2',0,0);
  5238. AssertSecondaryFile(AlterDB.Operations[1],'/my/file3',0,0);
  5239. end;
  5240. procedure TTestAlterDatabaseParser.TestFilesError;
  5241. begin
  5242. TestAlterError('ALTER DATABASE FILE ''/my/file2'' FILE ''/my/file3'' ');
  5243. end;
  5244. procedure TTestAlterDatabaseParser.TestError;
  5245. begin
  5246. TestAlterError('ALTER DATABASE ');
  5247. end;
  5248. procedure TTestAlterDatabaseParser.TestLength;
  5249. begin
  5250. TestAlter('ALTER DATABASE ADD FILE ''/my/file'' LENGTH 200');
  5251. AssertEquals('Operation count',1,AlterDB.Operations.Count);
  5252. AssertSecondaryFile(AlterDB.Operations[0],'/my/file',200,0);
  5253. end;
  5254. { TTestCreateViewParser }
  5255. function TTestCreateViewParser.TestCreate(const ASource: String
  5256. ): TSQLCreateViewStatement;
  5257. begin
  5258. CreateParser(ASource);
  5259. FToFree:=Parser.Parse;
  5260. Result:=TSQLCreateViewStatement(CheckClass(FToFree,TSQLCreateViewStatement));
  5261. FView:=Result;
  5262. AssertEquals('End of stream reached',tsqlEOF,Parser.CurrentToken);
  5263. end;
  5264. procedure TTestCreateViewParser.TestCreateError(const ASource: String);
  5265. begin
  5266. FerrSource:=ASource;
  5267. AssertException(ESQLParser,@TestParseError);
  5268. end;
  5269. procedure TTestCreateViewParser.TestSimple;
  5270. Var
  5271. S : TSQLSelectStatement;
  5272. begin
  5273. TestCreate('CREATE VIEW A AS SELECT B FROM C');
  5274. AssertIdentifierName('View name','A',View.ObjectName);
  5275. AssertNotNull('field list created',View.Fields);
  5276. AssertEquals('No fields in list',0,View.Fields.Count);
  5277. S:=TSQLSelectStatement(CheckClass(View.select,TSQLSelectStatement));
  5278. AssertEquals('1 Field',1,S.Fields.Count);
  5279. AssertField(S.Fields[0],'B','');
  5280. AssertEquals('1 table',1,S.Tables.Count);
  5281. AssertTable(S.Tables[0],'C','');
  5282. AssertEquals('No with check option',False,View.WithCheckOption);
  5283. end;
  5284. procedure TTestCreateViewParser.TestFieldList;
  5285. Var
  5286. S : TSQLSelectStatement;
  5287. begin
  5288. TestCreate('CREATE VIEW A (D) AS SELECT B FROM C');
  5289. AssertIdentifierName('View name','A',View.ObjectName);
  5290. AssertNotNull('field list created',View.Fields);
  5291. AssertEquals('1 field in list',1,View.Fields.Count);
  5292. AssertIdentifierName('Field name','D',View.Fields[0]);
  5293. S:=TSQLSelectStatement(CheckClass(View.select,TSQLSelectStatement));
  5294. AssertEquals('1 Field',1,S.Fields.Count);
  5295. AssertField(S.Fields[0],'B','');
  5296. AssertEquals('1 table',1,S.Tables.Count);
  5297. AssertTable(S.Tables[0],'C','');
  5298. AssertEquals('No with check option',False,View.WithCheckOption);
  5299. end;
  5300. procedure TTestCreateViewParser.TestFieldList2;
  5301. Var
  5302. S : TSQLSelectStatement;
  5303. begin
  5304. TestCreate('CREATE VIEW A (B,C) AS SELECT D,E FROM F');
  5305. AssertIdentifierName('View name','A',View.ObjectName);
  5306. AssertNotNull('field list created',View.Fields);
  5307. AssertEquals('2 fields in list',2,View.Fields.Count);
  5308. AssertIdentifierName('Field name','B',View.Fields[0]);
  5309. AssertIdentifierName('Field name','C',View.Fields[1]);
  5310. S:=TSQLSelectStatement(CheckClass(View.select,TSQLSelectStatement));
  5311. AssertEquals('2 Fields in select',2,S.Fields.Count);
  5312. AssertField(S.Fields[0],'D','');
  5313. AssertField(S.Fields[1],'E','');
  5314. AssertEquals('1 table',1,S.Tables.Count);
  5315. AssertTable(S.Tables[0],'F','');
  5316. AssertEquals('No with check option',False,View.WithCheckOption);
  5317. end;
  5318. procedure TTestCreateViewParser.TestSimpleWithCheckoption;
  5319. Var
  5320. S : TSQLSelectStatement;
  5321. begin
  5322. TestCreate('CREATE VIEW A AS SELECT B FROM C WITH CHECK OPTION');
  5323. AssertIdentifierName('View name','A',View.ObjectName);
  5324. AssertNotNull('field list created',View.Fields);
  5325. AssertEquals('No fields in list',0,View.Fields.Count);
  5326. S:=TSQLSelectStatement(CheckClass(View.select,TSQLSelectStatement));
  5327. AssertEquals('1 Field',1,S.Fields.Count);
  5328. AssertField(S.Fields[0],'B','');
  5329. AssertEquals('1 table',1,S.Tables.Count);
  5330. AssertTable(S.Tables[0],'C','');
  5331. AssertEquals('With check option',True,View.WithCheckOption);
  5332. end;
  5333. { TTestCreateShadowParser }
  5334. function TTestCreateShadowParser.TestCreate(const ASource: String
  5335. ): TSQLCreateShadowStatement;
  5336. begin
  5337. CreateParser(ASource);
  5338. FToFree:=Parser.Parse;
  5339. Result:=TSQLCreateShadowStatement(CheckClass(FToFree,TSQLCreateShadowStatement));
  5340. FShadow:=Result;
  5341. AssertEquals('End of stream reached',tsqlEOF,Parser.CurrentToken);
  5342. end;
  5343. procedure TTestCreateShadowParser.TestCreateError(const ASource: String);
  5344. begin
  5345. FerrSource:=ASource;
  5346. AssertException(ESQLParser,@TestParseError);
  5347. end;
  5348. procedure TTestCreateShadowParser.TestSimple;
  5349. begin
  5350. TestCreate('CREATE SHADOW 1 ''/my/file''');
  5351. AssertEquals('Not manual',False,Shadow.Manual);
  5352. AssertEquals('Not conditional',False,Shadow.COnditional);
  5353. AssertEquals('Filename','/my/file',Shadow.FileName);
  5354. AssertEquals('No length',0,Shadow.Length);
  5355. AssertEquals('No secondary files',0,Shadow.SecondaryFiles.Count);
  5356. end;
  5357. procedure TTestCreateShadowParser.TestLength;
  5358. begin
  5359. TestCreate('CREATE SHADOW 1 ''/my/file'' LENGTH 2');
  5360. AssertEquals('Not manual',False,Shadow.Manual);
  5361. AssertEquals('Not conditional',False,Shadow.COnditional);
  5362. AssertEquals('Filename','/my/file',Shadow.FileName);
  5363. AssertEquals('No length',2,Shadow.Length);
  5364. AssertEquals('No secondary files',0,Shadow.SecondaryFiles.Count);
  5365. end;
  5366. procedure TTestCreateShadowParser.TestLength2;
  5367. begin
  5368. TestCreate('CREATE SHADOW 1 ''/my/file'' LENGTH = 2');
  5369. AssertEquals('Not manual',False,Shadow.Manual);
  5370. AssertEquals('Not conditional',False,Shadow.COnditional);
  5371. AssertEquals('Filename','/my/file',Shadow.FileName);
  5372. AssertEquals('No length',2,Shadow.Length);
  5373. AssertEquals('No secondary files',0,Shadow.SecondaryFiles.Count);
  5374. end;
  5375. procedure TTestCreateShadowParser.TestLength3;
  5376. begin
  5377. TestCreate('CREATE SHADOW 1 ''/my/file'' LENGTH = 2 PAGE');
  5378. AssertEquals('Not manual',False,Shadow.Manual);
  5379. AssertEquals('Not conditional',False,Shadow.COnditional);
  5380. AssertEquals('Filename','/my/file',Shadow.FileName);
  5381. AssertEquals('No length',2,Shadow.Length);
  5382. AssertEquals('No secondary files',0,Shadow.SecondaryFiles.Count);
  5383. end;
  5384. procedure TTestCreateShadowParser.TestLength4;
  5385. begin
  5386. TestCreate('CREATE SHADOW 1 ''/my/file'' LENGTH = 2 PAGES');
  5387. AssertEquals('Not manual',False,Shadow.Manual);
  5388. AssertEquals('Not conditional',False,Shadow.COnditional);
  5389. AssertEquals('Filename','/my/file',Shadow.FileName);
  5390. AssertEquals('No length',2,Shadow.Length);
  5391. AssertEquals('No secondary files',0,Shadow.SecondaryFiles.Count);
  5392. end;
  5393. procedure TTestCreateShadowParser.TestSecondaryFile1;
  5394. begin
  5395. TestCreate('CREATE SHADOW 1 ''/my/file'' LENGTH 2 FILE ''/my/file2''');
  5396. AssertEquals('Not manual',False,Shadow.Manual);
  5397. AssertEquals('Not conditional',False,Shadow.COnditional);
  5398. AssertEquals('Filename','/my/file',Shadow.FileName);
  5399. AssertEquals('No length',2,Shadow.Length);
  5400. AssertEquals('1 secondary file',1,Shadow.SecondaryFiles.Count);
  5401. AssertSecondaryFile(Shadow.SecondaryFiles[0],'/my/file2',0,0);
  5402. end;
  5403. procedure TTestCreateShadowParser.TestSecondaryFile2;
  5404. begin
  5405. TestCreate('CREATE SHADOW 1 ''/my/file'' LENGTH 2 FILE ''/my/file2'' LENGTH 1000');
  5406. AssertEquals('Not manual',False,Shadow.Manual);
  5407. AssertEquals('Not conditional',False,Shadow.COnditional);
  5408. AssertEquals('Filename','/my/file',Shadow.FileName);
  5409. AssertEquals('No length',2,Shadow.Length);
  5410. AssertEquals('1 secondary file',1,Shadow.SecondaryFiles.Count);
  5411. AssertSecondaryFile(Shadow.SecondaryFiles[0],'/my/file2',1000,0);
  5412. end;
  5413. procedure TTestCreateShadowParser.TestSecondaryFile3;
  5414. begin
  5415. TestCreate('CREATE SHADOW 1 ''/my/file'' LENGTH 2 FILE ''/my/file2'' LENGTH = 1000');
  5416. AssertEquals('Not manual',False,Shadow.Manual);
  5417. AssertEquals('Not conditional',False,Shadow.COnditional);
  5418. AssertEquals('Filename','/my/file',Shadow.FileName);
  5419. AssertEquals('No length',2,Shadow.Length);
  5420. AssertEquals('1 secondary file',1,Shadow.SecondaryFiles.Count);
  5421. AssertSecondaryFile(Shadow.SecondaryFiles[0],'/my/file2',1000,0);
  5422. end;
  5423. procedure TTestCreateShadowParser.TestSecondaryFile4;
  5424. begin
  5425. TestCreate('CREATE SHADOW 1 ''/my/file'' LENGTH 2 FILE ''/my/file2'' LENGTH = 1000 PAGE');
  5426. AssertEquals('Not manual',False,Shadow.Manual);
  5427. AssertEquals('Not conditional',False,Shadow.COnditional);
  5428. AssertEquals('Filename','/my/file',Shadow.FileName);
  5429. AssertEquals('No length',2,Shadow.Length);
  5430. AssertEquals('1 secondary file',1,Shadow.SecondaryFiles.Count);
  5431. AssertSecondaryFile(Shadow.SecondaryFiles[0],'/my/file2',1000,0);
  5432. end;
  5433. procedure TTestCreateShadowParser.TestSecondaryFile5;
  5434. begin
  5435. TestCreate('CREATE SHADOW 1 ''/my/file'' LENGTH 2 FILE ''/my/file2'' LENGTH = 1000 PAGES');
  5436. AssertEquals('Not manual',False,Shadow.Manual);
  5437. AssertEquals('Not conditional',False,Shadow.COnditional);
  5438. AssertEquals('Filename','/my/file',Shadow.FileName);
  5439. AssertEquals('No length',2,Shadow.Length);
  5440. AssertEquals('1 secondary file',1,Shadow.SecondaryFiles.Count);
  5441. AssertSecondaryFile(Shadow.SecondaryFiles[0],'/my/file2',1000,0);
  5442. end;
  5443. procedure TTestCreateShadowParser.TestSecondaryFile6;
  5444. begin
  5445. TestCreate('CREATE SHADOW 1 ''/my/file'' LENGTH 2 FILE ''/my/file2'' STARTING 3000');
  5446. AssertEquals('Not manual',False,Shadow.Manual);
  5447. AssertEquals('Not conditional',False,Shadow.COnditional);
  5448. AssertEquals('Filename','/my/file',Shadow.FileName);
  5449. AssertEquals('No length',2,Shadow.Length);
  5450. AssertEquals('1 secondary file',1,Shadow.SecondaryFiles.Count);
  5451. AssertSecondaryFile(Shadow.SecondaryFiles[0],'/my/file2',0,3000);
  5452. end;
  5453. procedure TTestCreateShadowParser.TestSecondaryFile7;
  5454. begin
  5455. TestCreate('CREATE SHADOW 1 ''/my/file'' LENGTH 2 FILE ''/my/file2'' STARTING AT 3000');
  5456. AssertEquals('Not manual',False,Shadow.Manual);
  5457. AssertEquals('Not conditional',False,Shadow.COnditional);
  5458. AssertEquals('Filename','/my/file',Shadow.FileName);
  5459. AssertEquals('No length',2,Shadow.Length);
  5460. AssertEquals('1 secondary file',1,Shadow.SecondaryFiles.Count);
  5461. AssertSecondaryFile(Shadow.SecondaryFiles[0],'/my/file2',0,3000);
  5462. end;
  5463. procedure TTestCreateShadowParser.TestSecondaryFile8;
  5464. begin
  5465. TestCreate('CREATE SHADOW 1 ''/my/file'' LENGTH 2 FILE ''/my/file2'' STARTING AT PAGE 3000');
  5466. AssertEquals('Not manual',False,Shadow.Manual);
  5467. AssertEquals('Not conditional',False,Shadow.COnditional);
  5468. AssertEquals('Filename','/my/file',Shadow.FileName);
  5469. AssertEquals('No length',2,Shadow.Length);
  5470. AssertEquals('1 secondary file',1,Shadow.SecondaryFiles.Count);
  5471. AssertSecondaryFile(Shadow.SecondaryFiles[0],'/my/file2',0,3000);
  5472. end;
  5473. procedure TTestCreateShadowParser.TestSecondaryFileS;
  5474. begin
  5475. TestCreate('CREATE SHADOW 1 ''/my/file'' LENGTH 2 FILE ''/my/file2'' FILE ''/my/file3''');
  5476. AssertEquals('Not manual',False,Shadow.Manual);
  5477. AssertEquals('Not conditional',False,Shadow.COnditional);
  5478. AssertEquals('Filename','/my/file',Shadow.FileName);
  5479. AssertEquals('No length',2,Shadow.Length);
  5480. AssertEquals('2 secondary file',2,Shadow.SecondaryFiles.Count);
  5481. AssertSecondaryFile(Shadow.SecondaryFiles[0],'/my/file2',0,0);
  5482. AssertSecondaryFile(Shadow.SecondaryFiles[1],'/my/file3',0,0);
  5483. end;
  5484. { TTestProcedureStatement }
  5485. function TTestProcedureStatement.TestStatement(const ASource: String
  5486. ): TSQLStatement;
  5487. begin
  5488. CreateParser(ASource);
  5489. Parser.GetNextToken;
  5490. FToFree:=Parser.ParseProcedureStatements;
  5491. If not (FToFree is TSQLStatement) then
  5492. Fail('Not a TSQLStatement');
  5493. Result:=TSQLStatement(FToFree);
  5494. FSTatement:=Result;
  5495. AssertEquals('End of stream reached',tsqlEOF,Parser.CurrentToken);
  5496. end;
  5497. procedure TTestProcedureStatement.TestParseStatementError;
  5498. begin
  5499. CreateParser(FErrSource);
  5500. FToFree:=Parser.ParseProcedureStatements;
  5501. end;
  5502. procedure TTestProcedureStatement.TestStatementError(const ASource: String);
  5503. begin
  5504. FerrSource:=ASource;
  5505. AssertException(ESQLParser,@TestParseStatementError);
  5506. end;
  5507. procedure TTestProcedureStatement.TestException;
  5508. Var
  5509. E : TSQLExceptionStatement;
  5510. begin
  5511. E:=TSQLExceptionStatement(CheckClass(TestStatement('EXCEPTION MYE'),TSQLExceptionStatement));
  5512. AssertIdentifierName('Exception name','MYE',E.ExceptionName);
  5513. end;
  5514. procedure TTestProcedureStatement.TestExceptionError;
  5515. begin
  5516. TestStatementError('EXCEPTION ''MYE''');
  5517. end;
  5518. procedure TTestProcedureStatement.TestExit;
  5519. begin
  5520. CheckClass(TestStatement('EXIT'),TSQLExitStatement);
  5521. end;
  5522. procedure TTestProcedureStatement.TestSuspend;
  5523. begin
  5524. CheckClass(TestStatement('Suspend'),TSQLSuspendStatement);
  5525. end;
  5526. procedure TTestProcedureStatement.TestEmptyBlock;
  5527. Var
  5528. B : TSQLStatementBlock;
  5529. begin
  5530. B:=TSQLStatementBlock(CheckClass(TestStatement('BEGIN END'),TSQLStatementBlock));
  5531. AssertEquals('No statements',0,B.Statements.Count)
  5532. end;
  5533. procedure TTestProcedureStatement.TestExitBlock;
  5534. Var
  5535. B : TSQLStatementBlock;
  5536. begin
  5537. B:=TSQLStatementBlock(CheckClass(TestStatement('BEGIN EXIT; END'),TSQLStatementBlock));
  5538. AssertEquals('1 statement',1,B.Statements.Count);
  5539. CheckClass(B.Statements[0],TSQLExitStatement);
  5540. end;
  5541. procedure TTestProcedureStatement.TestExitBlockError;
  5542. begin
  5543. TestStatementError('BEGIN EXIT END')
  5544. end;
  5545. procedure TTestProcedureStatement.TestPostEvent;
  5546. Var
  5547. P : TSQLPostEventStatement;
  5548. begin
  5549. P:=TSQLPostEventStatement(CheckClass(TestStatement('POST_EVENT ''MYEVENT'''),TSQLPostEventStatement));
  5550. AssertEquals('Correct event name','MYEVENT' , P.EventName);
  5551. AssertNull('No event column',P.ColName);
  5552. end;
  5553. procedure TTestProcedureStatement.TestPostEventColName;
  5554. Var
  5555. P : TSQLPostEventStatement;
  5556. begin
  5557. P:=TSQLPostEventStatement(CheckClass(TestStatement('POST_EVENT MyColName'),TSQLPostEventStatement));
  5558. AssertEquals('Correct event name','' , P.EventName);
  5559. AssertIdentifierName('event column','MyColName',P.ColName);
  5560. end;
  5561. procedure TTestProcedureStatement.TestPostError;
  5562. begin
  5563. TestStatementError('POST_EVENT 1');
  5564. end;
  5565. procedure TTestProcedureStatement.TestAssignSimple;
  5566. Var
  5567. A : TSQLAssignStatement;
  5568. E : TSQLLiteralExpression;
  5569. I : TSQLIntegerLiteral;
  5570. begin
  5571. A:=TSQLAssignStatement(CheckClass(TestStatement('A=1'),TSQLAssignStatement));
  5572. AssertIdentifierName('Variable name','A',A.Variable);
  5573. E:=TSQLLiteralExpression(CheckClass(A.Expression,TSQLLiteralExpression));
  5574. I:=TSQLIntegerLiteral(CheckClass(E.Literal,TSQLIntegerLiteral));
  5575. AssertEquals('Correct value',1,I.Value);
  5576. end;
  5577. procedure TTestProcedureStatement.TestAssignSimpleNew;
  5578. Var
  5579. A : TSQLAssignStatement;
  5580. E : TSQLLiteralExpression;
  5581. I : TSQLIntegerLiteral;
  5582. begin
  5583. A:=TSQLAssignStatement(CheckClass(TestStatement('NEW.A=1'),TSQLAssignStatement));
  5584. AssertIdentifierName('Variable name','NEW.A',A.Variable);
  5585. E:=TSQLLiteralExpression(CheckClass(A.Expression,TSQLLiteralExpression));
  5586. I:=TSQLIntegerLiteral(CheckClass(E.Literal,TSQLIntegerLiteral));
  5587. AssertEquals('Correct value',1,I.Value);
  5588. end;
  5589. procedure TTestProcedureStatement.TestAssignSelect;
  5590. Var
  5591. A : TSQLAssignStatement;
  5592. S : TSQLSelectExpression;
  5593. begin
  5594. A:=TSQLAssignStatement(CheckClass(TestStatement('A=(SELECT B FROM C)'),TSQLAssignStatement));
  5595. AssertIdentifierName('Variable name','A',A.Variable);
  5596. S:=TSQLSelectExpression(CheckClass(A.Expression,TSQLSelectExpression));
  5597. AssertEquals('Field count',1,S.Select.Fields.Count);
  5598. AssertEquals('Table count',1,S.Select.Tables.Count);
  5599. AssertField(S.Select.Fields[0],'B','');
  5600. AssertTable(S.Select.Tables[0],'C','');
  5601. end;
  5602. procedure TTestProcedureStatement.TestBlockAssignSimple;
  5603. Var
  5604. A : TSQLAssignStatement;
  5605. E : TSQLLiteralExpression;
  5606. I : TSQLIntegerLiteral;
  5607. B : TSQLStatementBlock;
  5608. begin
  5609. B:=TSQLStatementBlock(CheckClass(TestStatement('BEGIN A=1; EXIT; END'),TSQLStatementBlock));
  5610. AssertEquals('2 statements',2,B.Statements.Count);
  5611. CheckClass(B.Statements[1],TSQLExitStatement);
  5612. A:=TSQLAssignStatement(CheckClass(B.Statements[0],TSQLAssignStatement));
  5613. AssertIdentifierName('Variable name','A',A.Variable);
  5614. E:=TSQLLiteralExpression(CheckClass(A.Expression,TSQLLiteralExpression));
  5615. I:=TSQLIntegerLiteral(CheckClass(E.Literal,TSQLIntegerLiteral));
  5616. AssertEquals('Correct value',1,I.Value);
  5617. end;
  5618. procedure TTestProcedureStatement.TestIf;
  5619. Var
  5620. I : TSQLIfStatement;
  5621. C : TSQLBinaryExpression;
  5622. E : TSQLLiteralExpression;
  5623. A : TSQLIdentifierExpression;
  5624. LI : TSQLIntegerLiteral;
  5625. begin
  5626. I:=TSQLIfStatement(CheckClass(TestStatement('IF (A=1) THEN EXIT'),TSQLIfStatement));
  5627. C:=TSQLBinaryExpression(CheckClass(I.Condition,TSQLBinaryExpression));
  5628. AssertEquals('Equals',boEq,C.Operation);
  5629. E:=TSQLLiteralExpression(CheckClass(C.Right,TSQLLiteralExpression));
  5630. LI:=TSQLIntegerLiteral(CheckClass(E.Literal,TSQLIntegerLiteral));
  5631. AssertEquals('Correct value',1,LI.Value);
  5632. A:=TSQLIdentifierExpression(CheckClass(C.Left,TSQLIdentifierExpression));
  5633. AssertIdentifierName('Variable name','A',A.Identifier);
  5634. CheckClass(I.TrueBranch,TSQLExitStatement);
  5635. end;
  5636. procedure TTestProcedureStatement.TestIfBlock;
  5637. Var
  5638. I : TSQLIfStatement;
  5639. C : TSQLBinaryExpression;
  5640. E : TSQLLiteralExpression;
  5641. A : TSQLIdentifierExpression;
  5642. LI : TSQLIntegerLiteral;
  5643. B : TSQLStatementBlock;
  5644. begin
  5645. I:=TSQLIfStatement(CheckClass(TestStatement('IF (A=1) THEN BEGIN EXIT; END'),TSQLIfStatement));
  5646. C:=TSQLBinaryExpression(CheckClass(I.Condition,TSQLBinaryExpression));
  5647. AssertEquals('Equals',boEq,C.Operation);
  5648. E:=TSQLLiteralExpression(CheckClass(C.Right,TSQLLiteralExpression));
  5649. LI:=TSQLIntegerLiteral(CheckClass(E.Literal,TSQLIntegerLiteral));
  5650. AssertEquals('Correct value',1,LI.Value);
  5651. A:=TSQLIdentifierExpression(CheckClass(C.Left,TSQLIdentifierExpression));
  5652. AssertIdentifierName('Variable name','A',A.Identifier);
  5653. B:=TSQLStatementBlock(CheckClass(I.TrueBranch,TSQLStatementBlock));
  5654. AssertEquals('1 statement',1,B.Statements.Count);
  5655. CheckClass(B.Statements[0],TSQLExitStatement);
  5656. end;
  5657. procedure TTestProcedureStatement.TestIfElse;
  5658. Var
  5659. I : TSQLIfStatement;
  5660. C : TSQLBinaryExpression;
  5661. E : TSQLLiteralExpression;
  5662. A : TSQLIdentifierExpression;
  5663. LI : TSQLIntegerLiteral;
  5664. begin
  5665. I:=TSQLIfStatement(CheckClass(TestStatement('IF (A=1) THEN EXIT; ELSE SUSPEND'),TSQLIfStatement));
  5666. C:=TSQLBinaryExpression(CheckClass(I.Condition,TSQLBinaryExpression));
  5667. AssertEquals('Equals',boEq,C.Operation);
  5668. E:=TSQLLiteralExpression(CheckClass(C.Right,TSQLLiteralExpression));
  5669. LI:=TSQLIntegerLiteral(CheckClass(E.Literal,TSQLIntegerLiteral));
  5670. AssertEquals('Correct value',1,LI.Value);
  5671. A:=TSQLIdentifierExpression(CheckClass(C.Left,TSQLIdentifierExpression));
  5672. AssertIdentifierName('Variable name','A',A.Identifier);
  5673. CheckClass(I.TrueBranch,TSQLExitStatement);
  5674. CheckClass(I.FalseBranch,TSQLSuspendStatement);
  5675. end;
  5676. procedure TTestProcedureStatement.TestIfBlockElse;
  5677. Var
  5678. I : TSQLIfStatement;
  5679. C : TSQLBinaryExpression;
  5680. E : TSQLLiteralExpression;
  5681. A : TSQLIdentifierExpression;
  5682. LI : TSQLIntegerLiteral;
  5683. B : TSQLStatementBlock;
  5684. begin
  5685. I:=TSQLIfStatement(CheckClass(TestStatement('IF (A=1) THEN BEGIN EXIT; END ELSE SUSPEND'),TSQLIfStatement));
  5686. C:=TSQLBinaryExpression(CheckClass(I.Condition,TSQLBinaryExpression));
  5687. AssertEquals('Equals',boEq,C.Operation);
  5688. E:=TSQLLiteralExpression(CheckClass(C.Right,TSQLLiteralExpression));
  5689. LI:=TSQLIntegerLiteral(CheckClass(E.Literal,TSQLIntegerLiteral));
  5690. AssertEquals('Correct value',1,LI.Value);
  5691. A:=TSQLIdentifierExpression(CheckClass(C.Left,TSQLIdentifierExpression));
  5692. AssertIdentifierName('Variable name','A',A.Identifier);
  5693. B:=TSQLStatementBlock(CheckClass(I.TrueBranch,TSQLStatementBlock));
  5694. AssertEquals('1 statement',1,B.Statements.Count);
  5695. CheckClass(B.Statements[0],TSQLExitStatement);
  5696. CheckClass(I.FalseBranch,TSQLSuspendStatement);
  5697. end;
  5698. procedure TTestProcedureStatement.TestIfElseError;
  5699. begin
  5700. TestStatementError('IF (A=B) THEN EXIT ELSE SUSPEND');
  5701. TestStatementError('IF (A=B) THEN BEGIN EXIT; END; ELSE SUSPEND');
  5702. end;
  5703. procedure TTestProcedureStatement.TestIfBlockElseBlock;
  5704. Var
  5705. I : TSQLIfStatement;
  5706. C : TSQLBinaryExpression;
  5707. E : TSQLLiteralExpression;
  5708. A : TSQLIdentifierExpression;
  5709. LI : TSQLIntegerLiteral;
  5710. B : TSQLStatementBlock;
  5711. begin
  5712. I:=TSQLIfStatement(CheckClass(TestStatement('IF (A=1) THEN BEGIN EXIT; END ELSE BEGIN SUSPEND; END'),TSQLIfStatement));
  5713. C:=TSQLBinaryExpression(CheckClass(I.Condition,TSQLBinaryExpression));
  5714. AssertEquals('Equals',boEq,C.Operation);
  5715. E:=TSQLLiteralExpression(CheckClass(C.Right,TSQLLiteralExpression));
  5716. LI:=TSQLIntegerLiteral(CheckClass(E.Literal,TSQLIntegerLiteral));
  5717. AssertEquals('Correct value',1,LI.Value);
  5718. A:=TSQLIdentifierExpression(CheckClass(C.Left,TSQLIdentifierExpression));
  5719. AssertIdentifierName('Variable name','A',A.Identifier);
  5720. B:=TSQLStatementBlock(CheckClass(I.TrueBranch,TSQLStatementBlock));
  5721. AssertEquals('1 statement',1,B.Statements.Count);
  5722. CheckClass(B.Statements[0],TSQLExitStatement);
  5723. B:=TSQLStatementBlock(CheckClass(I.FalseBranch,TSQLStatementBlock));
  5724. AssertEquals('1 statement',1,B.Statements.Count);
  5725. CheckClass(B.Statements[0],TSQLSuspendStatement);
  5726. end;
  5727. procedure TTestProcedureStatement.TestIfErrorBracketLeft;
  5728. begin
  5729. TestStatementError('IF A=1) THEN EXIT');
  5730. end;
  5731. procedure TTestProcedureStatement.TestIfErrorBracketRight;
  5732. begin
  5733. TestStatementError('IF (A=1 THEN EXIT');
  5734. end;
  5735. procedure TTestProcedureStatement.TestIfErrorNoThen;
  5736. begin
  5737. TestStatementError('IF (A=1) EXIT');
  5738. end;
  5739. procedure TTestProcedureStatement.TestIfErrorSemicolonElse;
  5740. begin
  5741. TestStatementError('IF (A=1) THEN EXIT; ELSE SUSPEND');
  5742. end;
  5743. procedure TTestProcedureStatement.TestWhile;
  5744. Var
  5745. W : TSQLWhileStatement;
  5746. C : TSQLBinaryExpression;
  5747. E : TSQLLiteralExpression;
  5748. A : TSQLIdentifierExpression;
  5749. LI : TSQLIntegerLiteral;
  5750. SA : TSQLAssignStatement;
  5751. begin
  5752. W:=TSQLWhileStatement(CheckClass(TestStatement('WHILE (A>1) DO A=A-1'),TSQLWhileStatement));
  5753. C:=TSQLBinaryExpression(CheckClass(W.Condition,TSQLBinaryExpression));
  5754. AssertEquals('Equals',boGT,C.Operation);
  5755. E:=TSQLLiteralExpression(CheckClass(C.Right,TSQLLiteralExpression));
  5756. LI:=TSQLIntegerLiteral(CheckClass(E.Literal,TSQLIntegerLiteral));
  5757. AssertEquals('Correct value',1,LI.Value);
  5758. A:=TSQLIdentifierExpression(CheckClass(C.Left,TSQLIdentifierExpression));
  5759. AssertIdentifierName('Variable name','A',A.Identifier);
  5760. SA:=TSQLAssignStatement(CheckClass(W.Statement,TSQLAssignStatement));
  5761. AssertIdentifierName('Variable name','A',SA.Variable);
  5762. // Check assignment expression
  5763. C:=TSQLBinaryExpression(CheckClass(SA.Expression,TSQLBinaryExpression));
  5764. AssertEquals('Equals',boAdd,C.Operation);
  5765. // Left operand
  5766. A:=TSQLIdentifierExpression(CheckClass(C.Left,TSQLIdentifierExpression));
  5767. AssertIdentifierName('Variable name','A',A.Identifier);
  5768. // Right operand
  5769. E:=TSQLLiteralExpression(CheckClass(C.Right,TSQLLiteralExpression));
  5770. LI:=TSQLIntegerLiteral(CheckClass(E.Literal,TSQLIntegerLiteral));
  5771. AssertEquals('Correct value',-1,LI.Value);
  5772. end;
  5773. procedure TTestProcedureStatement.TestWhileBlock;
  5774. Var
  5775. W : TSQLWhileStatement;
  5776. C : TSQLBinaryExpression;
  5777. E : TSQLLiteralExpression;
  5778. A : TSQLIdentifierExpression;
  5779. LI : TSQLIntegerLiteral;
  5780. SA : TSQLAssignStatement;
  5781. B : TSQLStatementBlock;
  5782. begin
  5783. W:=TSQLWhileStatement(CheckClass(TestStatement('WHILE (A>1) DO BEGIN A=A-1; END'),TSQLWhileStatement));
  5784. C:=TSQLBinaryExpression(CheckClass(W.Condition,TSQLBinaryExpression));
  5785. AssertEquals('Equals',boGT,C.Operation);
  5786. E:=TSQLLiteralExpression(CheckClass(C.Right,TSQLLiteralExpression));
  5787. LI:=TSQLIntegerLiteral(CheckClass(E.Literal,TSQLIntegerLiteral));
  5788. AssertEquals('Correct value',1,LI.Value);
  5789. A:=TSQLIdentifierExpression(CheckClass(C.Left,TSQLIdentifierExpression));
  5790. AssertIdentifierName('Variable name','A',A.Identifier);
  5791. B:=TSQLStatementBlock(CheckClass(W.Statement,TSQLStatementBlock));
  5792. AssertEquals('One statement',1,B.Statements.Count);
  5793. SA:=TSQLAssignStatement(CheckClass(B.Statements[0],TSQLAssignStatement));
  5794. AssertIdentifierName('Variable name','A',SA.Variable);
  5795. // Check assignment expression
  5796. C:=TSQLBinaryExpression(CheckClass(SA.Expression,TSQLBinaryExpression));
  5797. AssertEquals('Equals',boAdd,C.Operation);
  5798. // Left operand
  5799. A:=TSQLIdentifierExpression(CheckClass(C.Left,TSQLIdentifierExpression));
  5800. AssertIdentifierName('Variable name','A',A.Identifier);
  5801. // Right operand
  5802. E:=TSQLLiteralExpression(CheckClass(C.Right,TSQLLiteralExpression));
  5803. LI:=TSQLIntegerLiteral(CheckClass(E.Literal,TSQLIntegerLiteral));
  5804. AssertEquals('Correct value',-1,LI.Value);
  5805. end;
  5806. procedure TTestProcedureStatement.TestWhileErrorBracketLeft;
  5807. begin
  5808. TestStatementError('WHILE A>1) DO A=A-1');
  5809. end;
  5810. procedure TTestProcedureStatement.TestWhileErrorBracketRight;
  5811. begin
  5812. TestStatementError('WHILE (A>1 DO A=A-1');
  5813. end;
  5814. procedure TTestProcedureStatement.TestWhileErrorNoDo;
  5815. begin
  5816. TestStatementError('WHILE (A>1) A=A-1');
  5817. end;
  5818. procedure TTestProcedureStatement.TestWhenAny;
  5819. Var
  5820. W : TSQLWhenStatement;
  5821. begin
  5822. W:=TSQLWhenStatement(CheckClass(TestStatement('WHEN ANY DO EXIT'),TSQLWhenStatement));
  5823. AssertEquals('No error codes',0,W.Errors.Count);
  5824. AssertEquals('Any error',True,W.AnyError);
  5825. CheckClass(W.Statement,TSQLExitStatement);
  5826. end;
  5827. procedure TTestProcedureStatement.TestWhenSQLCode;
  5828. Var
  5829. W : TSQLWhenStatement;
  5830. E : TSQLWhenSQLError;
  5831. begin
  5832. W:=TSQLWhenStatement(CheckClass(TestStatement('WHEN SQLCODE 1 DO EXIT'),TSQLWhenStatement));
  5833. AssertEquals('Not Any error',False,W.AnyError);
  5834. AssertEquals('1 error code',1,W.Errors.Count);
  5835. CheckClass(W.Statement,TSQLExitStatement);
  5836. E:=TSQLWhenSQLError(CheckClass(W.Errors[0],TSQLWhenSQLError));
  5837. AssertEquals('Correct SQL Code',1,E.ErrorCode);
  5838. end;
  5839. procedure TTestProcedureStatement.TestWhenGDSCode;
  5840. Var
  5841. W : TSQLWhenStatement;
  5842. E : TSQLWhenGDSError;
  5843. begin
  5844. W:=TSQLWhenStatement(CheckClass(TestStatement('WHEN GDSCODE 1 DO EXIT'),TSQLWhenStatement));
  5845. AssertEquals('Not Any error',False,W.AnyError);
  5846. AssertEquals('1 error code',1,W.Errors.Count);
  5847. CheckClass(W.Statement,TSQLExitStatement);
  5848. E:=TSQLWhenGDSError(CheckClass(W.Errors[0],TSQLWhenGDSError));
  5849. AssertEquals('Correct SQL Code',1,E.GDSErrorNumber);
  5850. end;
  5851. procedure TTestProcedureStatement.TestWhenException;
  5852. Var
  5853. W : TSQLWhenStatement;
  5854. E : TSQLWhenException;
  5855. begin
  5856. W:=TSQLWhenStatement(CheckClass(TestStatement('WHEN EXCEPTION MYE DO EXIT'),TSQLWhenStatement));
  5857. AssertEquals('Not Any error',False,W.AnyError);
  5858. AssertEquals('1 error code',1,W.Errors.Count);
  5859. CheckClass(W.Statement,TSQLExitStatement);
  5860. E:=TSQLWhenException(CheckClass(W.Errors[0],TSQLWhenException));
  5861. AssertIdentifierName('Correct SQL Code','MYE',E.ExceptionName);
  5862. end;
  5863. procedure TTestProcedureStatement.TestWhenExceptionGDS;
  5864. Var
  5865. W : TSQLWhenStatement;
  5866. E : TSQLWhenException;
  5867. G : TSQLWhenGDSError;
  5868. begin
  5869. W:=TSQLWhenStatement(CheckClass(TestStatement('WHEN EXCEPTION MYE, GDSCODE 1 DO EXIT'),TSQLWhenStatement));
  5870. AssertEquals('Not Any error',False,W.AnyError);
  5871. AssertEquals('2 error code',2,W.Errors.Count);
  5872. CheckClass(W.Statement,TSQLExitStatement);
  5873. E:=TSQLWhenException(CheckClass(W.Errors[0],TSQLWhenException));
  5874. AssertIdentifierName('Correct SQL Code','MYE',E.ExceptionName);
  5875. G:=TSQLWhenGDSError(CheckClass(W.Errors[1],TSQLWhenGDSError));
  5876. AssertEquals('Correct SQL Code',1,G.GDSErrorNumber);
  5877. end;
  5878. procedure TTestProcedureStatement.TestWhenAnyBlock;
  5879. Var
  5880. W : TSQLWhenStatement;
  5881. B : TSQLStatementBlock;
  5882. begin
  5883. W:=TSQLWhenStatement(CheckClass(TestStatement('WHEN ANY DO BEGIN EXIT; END'),TSQLWhenStatement));
  5884. AssertEquals('No error codes',0,W.Errors.Count);
  5885. AssertEquals('Any error',True,W.AnyError);
  5886. B:=TSQLStatementBlock(CheckClass(W.Statement,TSQLStatementBlock));
  5887. AssertEquals('One statement',1,B.Statements.Count);
  5888. CheckClass(B.Statements[0],TSQLExitStatement);
  5889. end;
  5890. procedure TTestProcedureStatement.TestWhenErrorAny;
  5891. begin
  5892. TestStatementError('WHEN ANY, EXCEPTION MY DO EXIT');
  5893. end;
  5894. procedure TTestProcedureStatement.TestWhenErrorNoDo;
  5895. begin
  5896. TestStatementError('WHEN ANY EXIT');
  5897. end;
  5898. procedure TTestProcedureStatement.TestWhenErrorExceptionInt;
  5899. begin
  5900. TestStatementError('WHEN EXCEPTION 1 DO EXIT');
  5901. end;
  5902. procedure TTestProcedureStatement.TestWhenErrorExceptionString;
  5903. begin
  5904. TestStatementError('WHEN EXCEPTION ''1'' DO EXIT');
  5905. end;
  5906. procedure TTestProcedureStatement.TestWhenErrorSqlCode;
  5907. begin
  5908. TestStatementError('WHEN SQLCODE A DO EXIT');
  5909. end;
  5910. procedure TTestProcedureStatement.TestWhenErrorGDSCode;
  5911. begin
  5912. TestStatementError('WHEN GDSCODE A DO EXIT');
  5913. end;
  5914. procedure TTestProcedureStatement.TestExecuteStatement;
  5915. Var
  5916. E : TSQLExecuteProcedureStatement;
  5917. begin
  5918. E:=TSQLExecuteProcedureStatement(CheckClass(TestStatement('EXECUTE PROCEDURE A'),TSQLExecuteProcedureStatement));
  5919. AssertIDentifierName('Correct procedure','A',E.ProcedureName);
  5920. end;
  5921. procedure TTestProcedureStatement.TestExecuteStatementReturningValues;
  5922. Var
  5923. E : TSQLExecuteProcedureStatement;
  5924. begin
  5925. E:=TSQLExecuteProcedureStatement(CheckClass(TestStatement('EXECUTE PROCEDURE A RETURNING_VALUES B'),TSQLExecuteProcedureStatement));
  5926. AssertIDentifierName('Correct procedure','A',E.ProcedureName);
  5927. AssertEquals('Returning 1 value',1,E.Returning.Count);
  5928. AssertIDentifierName('Correct return value','B',E.Returning[0]);
  5929. end;
  5930. procedure TTestProcedureStatement.TestExecuteStatementReturningValuesColon;
  5931. Var
  5932. E : TSQLExecuteProcedureStatement;
  5933. begin
  5934. E:=TSQLExecuteProcedureStatement(CheckClass(TestStatement('EXECUTE PROCEDURE A RETURNING_VALUES :B'),TSQLExecuteProcedureStatement));
  5935. AssertIDentifierName('Correct procedure','A',E.ProcedureName);
  5936. AssertEquals('Returning 1 value',1,E.Returning.Count);
  5937. AssertIDentifierName('Correct return value','B',E.Returning[0]);
  5938. end;
  5939. procedure TTestProcedureStatement.TestExecuteStatementReturningValuesBrackets;
  5940. Var
  5941. E : TSQLExecuteProcedureStatement;
  5942. begin
  5943. E:=TSQLExecuteProcedureStatement(CheckClass(TestStatement('EXECUTE PROCEDURE A RETURNING_VALUES (:B)'),TSQLExecuteProcedureStatement));
  5944. AssertIDentifierName('Correct procedure','A',E.ProcedureName);
  5945. AssertEquals('Returning 1 value',1,E.Returning.Count);
  5946. AssertIDentifierName('Correct return value','B',E.Returning[0]);
  5947. end;
  5948. procedure TTestProcedureStatement.TestForSimple;
  5949. Var
  5950. F : TSQLForStatement;
  5951. P : TSQLPostEventStatement;
  5952. begin
  5953. F:=TSQLForStatement(CheckClass(TestStatement('FOR SELECT A FROM B INTO :C DO POST_EVENT C'),TSQLForStatement));
  5954. AssertEquals('Field count',1,F.Select.Fields.Count);
  5955. AssertEquals('Table count',1,F.Select.Tables.Count);
  5956. AssertField(F.Select.Fields[0],'A','');
  5957. AssertTable(F.Select.Tables[0],'B','');
  5958. AssertEquals('Into Fieldlist count',1,F.FieldList.Count);
  5959. AssertIdentifierName('Correct field name','C',F.FieldList[0]);
  5960. P:=TSQLPostEventStatement(CheckClass(F.Statement,TSQLPostEventStatement));
  5961. AssertIdentifierName('Event name','C',P.ColName);
  5962. end;
  5963. procedure TTestProcedureStatement.TestForSimpleNoColon;
  5964. Var
  5965. F : TSQLForStatement;
  5966. P : TSQLPostEventStatement;
  5967. begin
  5968. F:=TSQLForStatement(CheckClass(TestStatement('FOR SELECT A FROM B INTO C DO POST_EVENT C'),TSQLForStatement));
  5969. AssertEquals('Field count',1,F.Select.Fields.Count);
  5970. AssertEquals('Table count',1,F.Select.Tables.Count);
  5971. AssertField(F.Select.Fields[0],'A','');
  5972. AssertTable(F.Select.Tables[0],'B','');
  5973. AssertEquals('Into Fieldlist count',1,F.FieldList.Count);
  5974. AssertIdentifierName('Correct field name','C',F.FieldList[0]);
  5975. P:=TSQLPostEventStatement(CheckClass(F.Statement,TSQLPostEventStatement));
  5976. AssertIdentifierName('Event name','C',P.ColName);
  5977. end;
  5978. procedure TTestProcedureStatement.TestForSimple2fields;
  5979. Var
  5980. F : TSQLForStatement;
  5981. P : TSQLPostEventStatement;
  5982. begin
  5983. F:=TSQLForStatement(CheckClass(TestStatement('FOR SELECT A,B FROM C INTO :D,:E DO POST_EVENT D'),TSQLForStatement));
  5984. AssertEquals('Field count',2,F.Select.Fields.Count);
  5985. AssertEquals('Table count',1,F.Select.Tables.Count);
  5986. AssertField(F.Select.Fields[0],'A','');
  5987. AssertField(F.Select.Fields[1],'B','');
  5988. AssertTable(F.Select.Tables[0],'C','');
  5989. AssertEquals('Into Fieldlist count',2,F.FieldList.Count);
  5990. AssertIdentifierName('Correct field name','D',F.FieldList[0]);
  5991. AssertIdentifierName('Correct field name','E',F.FieldList[1]);
  5992. P:=TSQLPostEventStatement(CheckClass(F.Statement,TSQLPostEventStatement));
  5993. AssertIdentifierName('Event name','D',P.ColName);
  5994. end;
  5995. procedure TTestProcedureStatement.TestForBlock;
  5996. Var
  5997. F : TSQLForStatement;
  5998. P : TSQLPostEventStatement;
  5999. B : TSQLStatementBlock;
  6000. begin
  6001. F:=TSQLForStatement(CheckClass(TestStatement('FOR SELECT A FROM B INTO :C DO BEGIN POST_EVENT C; END'),TSQLForStatement));
  6002. AssertEquals('Field count',1,F.Select.Fields.Count);
  6003. AssertEquals('Table count',1,F.Select.Tables.Count);
  6004. AssertField(F.Select.Fields[0],'A','');
  6005. AssertTable(F.Select.Tables[0],'B','');
  6006. AssertEquals('Into Fieldlist count',1,F.FieldList.Count);
  6007. AssertIdentifierName('Correct field name','C',F.FieldList[0]);
  6008. B:=TSQLStatementBlock(CheckClass(F.Statement,TSQLStatementBlock));
  6009. AssertEquals('One statement',1,B.Statements.Count);
  6010. P:=TSQLPostEventStatement(CheckClass(B.Statements[0],TSQLPostEventStatement));
  6011. AssertIdentifierName('Event name','C',P.ColName);
  6012. end;
  6013. { TTestCreateProcedureParser }
  6014. function TTestCreateProcedureParser.TestCreate(const ASource: String
  6015. ): TSQLCreateProcedureStatement;
  6016. begin
  6017. CreateParser(ASource);
  6018. FToFree:=Parser.Parse;
  6019. Result:=TSQLCreateProcedureStatement(CheckClass(FToFree,TSQLCreateProcedureStatement));
  6020. FSTatement:=Result;
  6021. AssertEquals('End of stream reached',tsqlEOF,Parser.CurrentToken);
  6022. end;
  6023. procedure TTestCreateProcedureParser.TestCreateError(const ASource: String
  6024. );
  6025. begin
  6026. FErrSource:=ASource;
  6027. AssertException(ESQLParser,@TestParseError);
  6028. end;
  6029. procedure TTestCreateProcedureParser.TestEmptyProcedure;
  6030. begin
  6031. TestCreate('CREATE PROCEDURE A AS BEGIN END');
  6032. AssertIdentifierName('Correct procedure name','A',Statement.ObjectName);
  6033. AssertEquals('No arguments',0,Statement.InputVariables.Count);
  6034. AssertEquals('No return values',0,Statement.OutputVariables.Count);
  6035. AssertEquals('No local variables',0,Statement.LocalVariables.Count);
  6036. AssertEquals('No statements',0,Statement.Statements.Count);
  6037. end;
  6038. procedure TTestCreateProcedureParser.TestExitProcedure;
  6039. begin
  6040. TestCreate('CREATE PROCEDURE A AS BEGIN EXIT; END');
  6041. AssertIdentifierName('Correct procedure name','A',Statement.ObjectName);
  6042. AssertEquals('No arguments',0,Statement.InputVariables.Count);
  6043. AssertEquals('No return values',0,Statement.OutputVariables.Count);
  6044. AssertEquals('No local variables',0,Statement.LocalVariables.Count);
  6045. AssertEquals('One statement',1,Statement.Statements.Count);
  6046. CheckClass(Statement.Statements[0],TSQLExitStatement);
  6047. end;
  6048. procedure TTestCreateProcedureParser.TestProcedureOneArgument;
  6049. Var
  6050. P : TSQLProcedureParamDef;
  6051. begin
  6052. TestCreate('CREATE PROCEDURE A (P INT) AS BEGIN END');
  6053. AssertIdentifierName('Correct procedure name','A',Statement.ObjectName);
  6054. AssertEquals('1 arguments',1,Statement.InputVariables.Count);
  6055. P:=TSQLProcedureParamDef(CheckClass(Statement.InputVariables[0],TSQLProcedureParamDef));
  6056. AssertIdentifierName('Correct parameter name','P',P.ParamName);
  6057. AssertNotNull('Have type definition',P.ParamType);
  6058. AssertEquals('Correct type',sdtInteger,P.ParamType.DataType);
  6059. AssertEquals('No return values',0,Statement.OutputVariables.Count);
  6060. AssertEquals('No local variables',0,Statement.LocalVariables.Count);
  6061. AssertEquals('No statements',0,Statement.Statements.Count);
  6062. end;
  6063. procedure TTestCreateProcedureParser.TestProcedureTwoArguments;
  6064. Var
  6065. P : TSQLProcedureParamDef;
  6066. begin
  6067. TestCreate('CREATE PROCEDURE A (P INT,Q CHAR(4)) AS BEGIN END');
  6068. AssertIdentifierName('Correct procedure name','A',Statement.ObjectName);
  6069. AssertEquals('Two arguments',2,Statement.InputVariables.Count);
  6070. P:=TSQLProcedureParamDef(CheckClass(Statement.InputVariables[0],TSQLProcedureParamDef));
  6071. AssertIdentifierName('Correct parameter name','P',P.ParamName);
  6072. AssertNotNull('Have type definition',P.ParamType);
  6073. AssertEquals('Correct type',sdtInteger,P.ParamType.DataType);
  6074. AssertEquals('No return values',0,Statement.OutputVariables.Count);
  6075. P:=TSQLProcedureParamDef(CheckClass(Statement.InputVariables[1],TSQLProcedureParamDef));
  6076. AssertIdentifierName('Correct parameter name','Q',P.ParamName);
  6077. AssertNotNull('Have type definition',P.ParamType);
  6078. AssertEquals('Correct type',sdtChar,P.ParamType.DataType);
  6079. AssertEquals('Correct length',4,P.ParamType.Len);
  6080. //
  6081. AssertEquals('No local variables',0,Statement.LocalVariables.Count);
  6082. AssertEquals('No statements',0,Statement.Statements.Count);
  6083. end;
  6084. procedure TTestCreateProcedureParser.TestProcedureOneReturnValue;
  6085. Var
  6086. P : TSQLProcedureParamDef;
  6087. begin
  6088. TestCreate('CREATE PROCEDURE A RETURNS (P INT) AS BEGIN END');
  6089. AssertIdentifierName('Correct procedure name','A',Statement.ObjectName);
  6090. AssertEquals('1 return value',1,Statement.OutputVariables.Count);
  6091. P:=TSQLProcedureParamDef(CheckClass(Statement.OutputVariables[0],TSQLProcedureParamDef));
  6092. AssertIdentifierName('Correct parameter name','P',P.ParamName);
  6093. AssertNotNull('Have type definition',P.ParamType);
  6094. AssertEquals('Correct type',sdtInteger,P.ParamType.DataType);
  6095. AssertEquals('No input values',0,Statement.InputVariables.Count);
  6096. AssertEquals('No local variables',0,Statement.LocalVariables.Count);
  6097. AssertEquals('No statements',0,Statement.Statements.Count);
  6098. end;
  6099. procedure TTestCreateProcedureParser.TestProcedureTwoReturnValues;
  6100. Var
  6101. P : TSQLProcedureParamDef;
  6102. begin
  6103. TestCreate('CREATE PROCEDURE A RETURNS (P INT, Q CHAR(5)) AS BEGIN END');
  6104. AssertIdentifierName('Correct procedure name','A',Statement.ObjectName);
  6105. AssertEquals('2 return values',2,Statement.OutputVariables.Count);
  6106. P:=TSQLProcedureParamDef(CheckClass(Statement.OutputVariables[0],TSQLProcedureParamDef));
  6107. AssertIdentifierName('Correct parameter name','P',P.ParamName);
  6108. AssertNotNull('Have type definition',P.ParamType);
  6109. AssertEquals('Correct type',sdtInteger,P.ParamType.DataType);
  6110. P:=TSQLProcedureParamDef(CheckClass(Statement.OutputVariables[1],TSQLProcedureParamDef));
  6111. AssertIdentifierName('Correct parameter name','Q',P.ParamName);
  6112. AssertNotNull('Have type definition',P.ParamType);
  6113. AssertEquals('Correct type',sdtChar,P.ParamType.DataType);
  6114. AssertEquals('Correct length',5,P.ParamType.Len);
  6115. AssertEquals('No input values',0,Statement.InputVariables.Count);
  6116. AssertEquals('No local variables',0,Statement.LocalVariables.Count);
  6117. AssertEquals('No statements',0,Statement.Statements.Count);
  6118. end;
  6119. procedure TTestCreateProcedureParser.TestProcedureOneLocalVariable;
  6120. Var
  6121. P : TSQLProcedureParamDef;
  6122. begin
  6123. TestCreate('CREATE PROCEDURE A AS DECLARE VARIABLE P INT; BEGIN END');
  6124. AssertIdentifierName('Correcte procedure naam','A',Statement.ObjectName);
  6125. AssertEquals('0 return values',0,Statement.OutputVariables.Count);
  6126. AssertEquals('1 local variable',1,Statement.LocalVariables.Count);
  6127. P:=TSQLProcedureParamDef(CheckClass(Statement.LocalVariables[0],TSQLProcedureParamDef));
  6128. AssertIdentifierName('Correct parameter name','P',P.ParamName);
  6129. AssertNotNull('Have type definition',P.ParamType);
  6130. AssertEquals('Correct type',sdtInteger,P.ParamType.DataType);
  6131. AssertEquals('No input values',0,Statement.InputVariables.Count);
  6132. AssertEquals('No statements',0,Statement.Statements.Count);
  6133. end;
  6134. procedure TTestCreateProcedureParser.TestProcedureTwoLocalVariable;
  6135. Var
  6136. P : TSQLProcedureParamDef;
  6137. begin
  6138. TestCreate('CREATE PROCEDURE A AS DECLARE VARIABLE P INT; DECLARE VARIABLE Q CHAR(5); BEGIN END');
  6139. AssertIdentifierName('Correcte procedure naam','A',Statement.ObjectName);
  6140. AssertEquals('0 return values',0,Statement.OutputVariables.Count);
  6141. AssertEquals('2 local variable',2,Statement.LocalVariables.Count);
  6142. P:=TSQLProcedureParamDef(CheckClass(Statement.LocalVariables[0],TSQLProcedureParamDef));
  6143. AssertIdentifierName('Correct parameter name','P',P.ParamName);
  6144. AssertNotNull('Have type definition',P.ParamType);
  6145. AssertEquals('Correct type',sdtInteger,P.ParamType.DataType);
  6146. P:=TSQLProcedureParamDef(CheckClass(Statement.LocalVariables[1],TSQLProcedureParamDef));
  6147. AssertIdentifierName('Correct parameter name','Q',P.ParamName);
  6148. AssertNotNull('Have type definition',P.ParamType);
  6149. AssertEquals('Correct type',sdtChar,P.ParamType.DataType);
  6150. AssertEquals('Correct length',5,P.ParamType.Len);
  6151. AssertEquals('No input values',0,Statement.InputVariables.Count);
  6152. AssertEquals('No statements',0,Statement.Statements.Count);
  6153. end;
  6154. procedure TTestCreateProcedureParser.TestProcedureInputOutputLocal;
  6155. Var
  6156. P : TSQLProcedureParamDef;
  6157. begin
  6158. TestCreate('CREATE PROCEDURE A (P INT) RETURNS (Q CHAR(5)) AS DECLARE VARIABLE R VARCHAR(5); BEGIN END');
  6159. AssertIdentifierName('Correcte procedure naam','A',Statement.ObjectName);
  6160. // Input
  6161. AssertEquals('1 input value',1,Statement.InputVariables.Count);
  6162. P:=TSQLProcedureParamDef(CheckClass(Statement.InputVariables[0],TSQLProcedureParamDef));
  6163. AssertIdentifierName('Correct parameter name','P',P.ParamName);
  6164. AssertNotNull('Have type definition',P.ParamType);
  6165. AssertEquals('Correct type',sdtInteger,P.ParamType.DataType);
  6166. // Output
  6167. AssertEquals('1 return values',1,Statement.OutputVariables.Count);
  6168. P:=TSQLProcedureParamDef(CheckClass(Statement.OutputVariables[0],TSQLProcedureParamDef));
  6169. AssertIdentifierName('Correct parameter name','Q',P.ParamName);
  6170. AssertNotNull('Have type definition',P.ParamType);
  6171. AssertEquals('Correct type',sdtChar,P.ParamType.DataType);
  6172. AssertEquals('Correct length',5,P.ParamType.Len);
  6173. // Local
  6174. AssertEquals('1 local variable',1,Statement.LocalVariables.Count);
  6175. P:=TSQLProcedureParamDef(CheckClass(Statement.LocalVariables[0],TSQLProcedureParamDef));
  6176. AssertIdentifierName('Correct parameter name','R',P.ParamName);
  6177. AssertNotNull('Have type definition',P.ParamType);
  6178. AssertEquals('Correct type',sdtvarChar,P.ParamType.DataType);
  6179. AssertEquals('Correct length',5,P.ParamType.Len);
  6180. AssertEquals('No statements',0,Statement.Statements.Count);
  6181. end;
  6182. { TTestCreateTriggerParser }
  6183. function TTestCreateTriggerParser.TestCreate(const ASource: String
  6184. ): TSQLCreateTriggerStatement;
  6185. begin
  6186. CreateParser(ASource);
  6187. FToFree:=Parser.Parse;
  6188. Result:=TSQLCreateTriggerStatement(CheckClass(FToFree,TSQLCreateTriggerStatement));
  6189. FSTatement:=Result;
  6190. AssertEquals('End of stream reached',tsqlEOF,Parser.CurrentToken);
  6191. end;
  6192. function TTestCreateTriggerParser.TestAlter(const ASource: String
  6193. ): TSQLAlterTriggerStatement;
  6194. begin
  6195. CreateParser(ASource);
  6196. FToFree:=Parser.Parse;
  6197. Result:=TSQLAlterTriggerStatement(CheckClass(FToFree,TSQLAlterTriggerStatement));
  6198. FSTatement:=Result;
  6199. AssertEquals('End of stream reached',tsqlEOF,Parser.CurrentToken);
  6200. end;
  6201. procedure TTestCreateTriggerParser.TestCreateError(const ASource: String);
  6202. begin
  6203. FErrSource:=ASource;
  6204. AssertException(ESQLParser,@TestParseError);
  6205. end;
  6206. procedure TTestCreateTriggerParser.TestEmptyTrigger;
  6207. begin
  6208. TestCreate('CREATE TRIGGER A FOR B BEFORE UPDATE AS BEGIN END');
  6209. AssertIdentifierName('Correct trigger name','A',Statement.ObjectName);
  6210. AssertIdentifierName('Correct table','B',Statement.TableName);
  6211. AssertEquals('No variables',0,Statement.LocalVariables.Count);
  6212. AssertEquals('No Statements',0,Statement.Statements.Count);
  6213. AssertEquals('No position',0,Statement.Position);
  6214. AssertEquals('No active/inactive',tsNone,Statement.State);
  6215. AssertEquals('Before moment',tmBefore,Statement.Moment);
  6216. AssertEquals('Update operation',[toUpdate],Statement.Operations);
  6217. end;
  6218. procedure TTestCreateTriggerParser.TestExitTrigger;
  6219. begin
  6220. TestCreate('CREATE TRIGGER A FOR B BEFORE UPDATE AS BEGIN EXIT; END');
  6221. AssertIdentifierName('Correct trigger name','A',Statement.ObjectName);
  6222. AssertIdentifierName('Correct table','B',Statement.TableName);
  6223. AssertEquals('No variables',0,Statement.LocalVariables.Count);
  6224. AssertEquals('1 Statements',1,Statement.Statements.Count);
  6225. AssertEquals('No position',0,Statement.Position);
  6226. AssertEquals('No active/inactive',tsNone,Statement.State);
  6227. AssertEquals('Before moment',tmBefore,Statement.Moment);
  6228. AssertEquals('Update operation',[toUpdate],Statement.Operations);
  6229. CheckClass(Statement.Statements[0],TSQLExitStatement);
  6230. end;
  6231. procedure TTestCreateTriggerParser.TestEmptyTriggerAfterUpdate;
  6232. begin
  6233. TestCreate('CREATE TRIGGER A FOR B AFTER UPDATE AS BEGIN END');
  6234. AssertIdentifierName('Correct trigger name','A',Statement.ObjectName);
  6235. AssertIdentifierName('Correct table','B',Statement.TableName);
  6236. AssertEquals('No variables',0,Statement.LocalVariables.Count);
  6237. AssertEquals('No Statements',0,Statement.Statements.Count);
  6238. AssertEquals('No position',0,Statement.Position);
  6239. AssertEquals('No active/inactive',tsNone,Statement.State);
  6240. AssertEquals('Before moment',tmAfter,Statement.Moment);
  6241. AssertEquals('Update operation',[toUpdate],Statement.Operations);
  6242. end;
  6243. procedure TTestCreateTriggerParser.TestEmptyTriggerBeforeDelete;
  6244. begin
  6245. TestCreate('CREATE TRIGGER A FOR B BEFORE DELETE AS BEGIN END');
  6246. AssertIdentifierName('Correct trigger name','A',Statement.ObjectName);
  6247. AssertIdentifierName('Correct table','B',Statement.TableName);
  6248. AssertEquals('No variables',0,Statement.LocalVariables.Count);
  6249. AssertEquals('No Statements',0,Statement.Statements.Count);
  6250. AssertEquals('No position',0,Statement.Position);
  6251. AssertEquals('No active/inactive',tsNone,Statement.State);
  6252. AssertEquals('Before moment',tmBefore,Statement.Moment);
  6253. AssertEquals('Delete operation',[toDelete],Statement.Operations);
  6254. end;
  6255. procedure TTestCreateTriggerParser.TestEmptyTriggerBeforeInsert;
  6256. begin
  6257. TestCreate('CREATE TRIGGER A FOR B BEFORE INSERT AS BEGIN END');
  6258. AssertIdentifierName('Correct trigger name','A',Statement.ObjectName);
  6259. AssertIdentifierName('Correct table','B',Statement.TableName);
  6260. AssertEquals('No variables',0,Statement.LocalVariables.Count);
  6261. AssertEquals('No Statements',0,Statement.Statements.Count);
  6262. AssertEquals('No position',0,Statement.Position);
  6263. AssertEquals('No active/inactive',tsNone,Statement.State);
  6264. AssertEquals('Before moment',tmBefore,Statement.Moment);
  6265. AssertEquals('Insert operation',[toInsert],Statement.Operations);
  6266. end;
  6267. procedure TTestCreateTriggerParser.TestEmptyTriggerBeforeInsertPosition1;
  6268. begin
  6269. TestCreate('CREATE TRIGGER A FOR B BEFORE INSERT POSITION 1 AS BEGIN END');
  6270. AssertIdentifierName('Correct trigger name','A',Statement.ObjectName);
  6271. AssertIdentifierName('Correct table','B',Statement.TableName);
  6272. AssertEquals('No variables',0,Statement.LocalVariables.Count);
  6273. AssertEquals('No Statements',0,Statement.Statements.Count);
  6274. AssertEquals('position 1',1,Statement.Position);
  6275. AssertEquals('No active/inactive',tsNone,Statement.State);
  6276. AssertEquals('Before moment',tmBefore,Statement.Moment);
  6277. AssertEquals('Insert operation',[toInsert],Statement.Operations);
  6278. end;
  6279. procedure TTestCreateTriggerParser.TestEmptyTriggerBeforeInsertPosition1inActive;
  6280. begin
  6281. TestCreate('CREATE TRIGGER A FOR B INACTIVE BEFORE INSERT POSITION 1 AS BEGIN END');
  6282. AssertIdentifierName('Correct trigger name','A',Statement.ObjectName);
  6283. AssertIdentifierName('Correct table','B',Statement.TableName);
  6284. AssertEquals('No variables',0,Statement.LocalVariables.Count);
  6285. AssertEquals('No Statements',0,Statement.Statements.Count);
  6286. AssertEquals('position 1',1,Statement.Position);
  6287. AssertEquals('inactive',tsInactive,Statement.State);
  6288. AssertEquals('Before moment',tmBefore,Statement.Moment);
  6289. AssertEquals('Insert operation',[toInsert],Statement.Operations);
  6290. end;
  6291. procedure TTestCreateTriggerParser.TestEmptyTriggerBeforeInsertPosition1Active;
  6292. begin
  6293. TestCreate('CREATE TRIGGER A FOR B ACTIVE BEFORE INSERT POSITION 1 AS BEGIN END');
  6294. AssertIdentifierName('Correct trigger name','A',Statement.ObjectName);
  6295. AssertIdentifierName('Correct table','B',Statement.TableName);
  6296. AssertEquals('No variables',0,Statement.LocalVariables.Count);
  6297. AssertEquals('No Statements',0,Statement.Statements.Count);
  6298. AssertEquals('position 1',1,Statement.Position);
  6299. AssertEquals('Active',tsActive,Statement.State);
  6300. AssertEquals('Before moment',tmBefore,Statement.Moment);
  6301. AssertEquals('Insert operation',[toInsert],Statement.Operations);
  6302. end;
  6303. procedure TTestCreateTriggerParser.TestTriggerOneLocalVariable;
  6304. Var
  6305. P : TSQLProcedureParamDef;
  6306. begin
  6307. TestCreate('CREATE TRIGGER A FOR B ACTIVE BEFORE INSERT POSITION 1 AS DECLARE VARIABLE P INT; BEGIN END');
  6308. AssertIdentifierName('Correcte procedure naam','A',Statement.ObjectName);
  6309. AssertIdentifierName('Correct table','B',Statement.TableName);
  6310. AssertEquals('No Statements',0,Statement.Statements.Count);
  6311. AssertEquals('position 1',1,Statement.Position);
  6312. AssertEquals('Active',tsActive,Statement.State);
  6313. AssertEquals('Before moment',tmBefore,Statement.Moment);
  6314. AssertEquals('Insert operation',[toInsert],Statement.Operations);
  6315. AssertEquals('1 local variable',1,Statement.LocalVariables.Count);
  6316. P:=TSQLProcedureParamDef(CheckClass(Statement.LocalVariables[0],TSQLProcedureParamDef));
  6317. AssertIdentifierName('Correct parameter name','P',P.ParamName);
  6318. AssertNotNull('Have type definition',P.ParamType);
  6319. AssertEquals('Correct type',sdtInteger,P.ParamType.DataType);
  6320. end;
  6321. procedure TTestCreateTriggerParser.TestTriggerTwoLocalVariables;
  6322. Var
  6323. P : TSQLProcedureParamDef;
  6324. begin
  6325. TestCreate('CREATE TRIGGER A FOR B ACTIVE BEFORE INSERT POSITION 1 AS DECLARE VARIABLE P INT; DECLARE VARIABLE Q INT; BEGIN END');
  6326. AssertIdentifierName('Correcte procedure naam','A',Statement.ObjectName);
  6327. AssertIdentifierName('Correct table','B',Statement.TableName);
  6328. AssertEquals('No Statements',0,Statement.Statements.Count);
  6329. AssertEquals('position 1',1,Statement.Position);
  6330. AssertEquals('Active',tsActive,Statement.State);
  6331. AssertEquals('Before moment',tmBefore,Statement.Moment);
  6332. AssertEquals('Insert operation',[toInsert],Statement.Operations);
  6333. AssertEquals('2 local variables',2,Statement.LocalVariables.Count);
  6334. P:=TSQLProcedureParamDef(CheckClass(Statement.LocalVariables[0],TSQLProcedureParamDef));
  6335. AssertIdentifierName('Correct parameter name','P',P.ParamName);
  6336. AssertNotNull('Have type definition',P.ParamType);
  6337. AssertEquals('Correct type',sdtInteger,P.ParamType.DataType);
  6338. P:=TSQLProcedureParamDef(CheckClass(Statement.LocalVariables[1],TSQLProcedureParamDef));
  6339. AssertIdentifierName('Correct parameter name','Q',P.ParamName);
  6340. AssertNotNull('Have type definition',P.ParamType);
  6341. AssertEquals('Correct type',sdtInteger,P.ParamType.DataType);
  6342. end;
  6343. procedure TTestCreateTriggerParser.TestAlterTrigger;
  6344. begin
  6345. TestAlter('ALTER TRIGGER A BEFORE UPDATE AS BEGIN END');
  6346. AssertIdentifierName('Correct trigger name','A',Statement.ObjectName);
  6347. AssertNull('Correct table',Statement.TableName);
  6348. AssertEquals('No variables',0,Statement.LocalVariables.Count);
  6349. AssertEquals('No Statements',0,Statement.Statements.Count);
  6350. AssertEquals('No position',0,Statement.Position);
  6351. AssertEquals('No active/inactive',tsNone,Statement.State);
  6352. AssertEquals('Before moment',tmBefore,Statement.Moment);
  6353. AssertEquals('Update operation',[toUpdate],Statement.Operations);
  6354. end;
  6355. { TTestDeclareExternalFunctionParser }
  6356. function TTestDeclareExternalFunctionParser.TestCreate(const ASource: String
  6357. ): TSQLDeclareExternalFunctionStatement;
  6358. begin
  6359. CreateParser(ASource);
  6360. FToFree:=Parser.Parse;
  6361. Result:=TSQLDeclareExternalFunctionStatement(CheckClass(FToFree,TSQLDeclareExternalFunctionStatement));
  6362. FSTatement:=Result;
  6363. AssertEquals('End of stream reached',tsqlEOF,Parser.CurrentToken);
  6364. end;
  6365. procedure TTestDeclareExternalFunctionParser.TestCreateError(
  6366. const ASource: String);
  6367. begin
  6368. FErrSource:=ASource;
  6369. AssertException(ESQLParser,@TestParseError);
  6370. end;
  6371. procedure TTestDeclareExternalFunctionParser.TestEmptyfunction;
  6372. begin
  6373. TestCreate('DECLARE EXTERNAL FUNCTION A RETURNS INT ENTRY_POINT ''A'' MODULE_NAME ''B''');
  6374. AssertIdentifierName('Correct function','A',Statement.ObjectName);
  6375. AssertEquals('Correct entry point','A',Statement.EntryPoint);
  6376. AssertEquals('Correct module name','B',Statement.ModuleName);
  6377. AssertEquals('No arguments',0,Statement.Arguments.Count);
  6378. AssertNotNull('Have return type',Statement.ReturnType);
  6379. AssertEquals('No FreeIt',False,Statement.FreeIt);
  6380. AssertEquals('Correct return type',sdtInteger,Statement.ReturnType.DataType);
  6381. end;
  6382. procedure TTestDeclareExternalFunctionParser.TestEmptyfunctionByValue;
  6383. begin
  6384. TestCreate('DECLARE EXTERNAL FUNCTION A RETURNS INT BY VALUE ENTRY_POINT ''A'' MODULE_NAME ''B''');
  6385. AssertIdentifierName('Correct function','A',Statement.ObjectName);
  6386. AssertEquals('Correct entry point','A',Statement.EntryPoint);
  6387. AssertEquals('Correct module name','B',Statement.ModuleName);
  6388. AssertEquals('No arguments',0,Statement.Arguments.Count);
  6389. AssertNotNull('Have return type',Statement.ReturnType);
  6390. AssertEquals('No FreeIt',False,Statement.FreeIt);
  6391. AssertEquals('Correct return type',sdtInteger,Statement.ReturnType.DataType);
  6392. AssertEquals('By Value',True,Statement.ReturnType.ByValue);
  6393. end;
  6394. procedure TTestDeclareExternalFunctionParser.TestCStringfunction;
  6395. begin
  6396. TestCreate('DECLARE EXTERNAL FUNCTION A RETURNS CSTRING (50) ENTRY_POINT ''A'' MODULE_NAME ''B''');
  6397. AssertIdentifierName('Correct function','A',Statement.ObjectName);
  6398. AssertEquals('Correct entry point','A',Statement.EntryPoint);
  6399. AssertEquals('Correct module name','B',Statement.ModuleName);
  6400. AssertEquals('No arguments',0,Statement.Arguments.Count);
  6401. AssertNotNull('Have return type',Statement.ReturnType);
  6402. AssertEquals('No FreeIt',False,Statement.FreeIt);
  6403. AssertEquals('Correct return type',sdtCstring,Statement.ReturnType.DataType);
  6404. AssertEquals('Correct return length',50,Statement.ReturnType.Len);
  6405. end;
  6406. procedure TTestDeclareExternalFunctionParser.TestCStringFreeItfunction;
  6407. begin
  6408. TestCreate('DECLARE EXTERNAL FUNCTION A RETURNS CSTRING (50) FREE_IT ENTRY_POINT ''A'' MODULE_NAME ''B''');
  6409. AssertIdentifierName('Correct function','A',Statement.ObjectName);
  6410. AssertEquals('Correct entry point','A',Statement.EntryPoint);
  6411. AssertEquals('Correct module name','B',Statement.ModuleName);
  6412. AssertEquals('No arguments',0,Statement.Arguments.Count);
  6413. AssertNotNull('Have return type',Statement.ReturnType);
  6414. AssertEquals('FreeIt',True,Statement.FreeIt);
  6415. AssertEquals('Correct return type',sdtCstring,Statement.ReturnType.DataType);
  6416. AssertEquals('Correct return length',50,Statement.ReturnType.Len);
  6417. end;
  6418. procedure TTestDeclareExternalFunctionParser.TestOneArgumentFunction;
  6419. Var
  6420. T : TSQLTypeDefinition;
  6421. begin
  6422. TestCreate('DECLARE EXTERNAL FUNCTION A INT RETURNS INT ENTRY_POINT ''A'' MODULE_NAME ''B''');
  6423. AssertIdentifierName('Correct function','A',Statement.ObjectName);
  6424. AssertEquals('Correct entry point','A',Statement.EntryPoint);
  6425. AssertEquals('Correct module name','B',Statement.ModuleName);
  6426. AssertEquals('1 argument',1,Statement.Arguments.Count);
  6427. T:=TSQLTypeDefinition(CheckClass(Statement.Arguments[0],TSQLTypeDefinition));
  6428. AssertEquals('Correct return type',sdtInteger,T.DataType);
  6429. AssertNotNull('Have return type',Statement.ReturnType);
  6430. AssertEquals('No FreeIt',False,Statement.FreeIt);
  6431. AssertEquals('Correct return type',sdtInteger,Statement.ReturnType.DataType);
  6432. end;
  6433. procedure TTestDeclareExternalFunctionParser.TestTwoArgumentsFunction;
  6434. Var
  6435. T : TSQLTypeDefinition;
  6436. begin
  6437. TestCreate('DECLARE EXTERNAL FUNCTION A INT, CSTRING(10) RETURNS INT ENTRY_POINT ''A'' MODULE_NAME ''B''');
  6438. AssertIdentifierName('Correct function','A',Statement.ObjectName);
  6439. AssertEquals('Correct entry point','A',Statement.EntryPoint);
  6440. AssertEquals('Correct module name','B',Statement.ModuleName);
  6441. AssertEquals('2 arguments',2,Statement.Arguments.Count);
  6442. T:=TSQLTypeDefinition(CheckClass(Statement.Arguments[0],TSQLTypeDefinition));
  6443. AssertEquals('Correct argument type',sdtInteger,T.DataType);
  6444. T:=TSQLTypeDefinition(CheckClass(Statement.Arguments[1],TSQLTypeDefinition));
  6445. AssertEquals('Correct return type',sdtCstring,T.DataType);
  6446. AssertEquals('Correct argument length',10,T.Len);
  6447. AssertNotNull('Have return type',Statement.ReturnType);
  6448. AssertEquals('No FreeIt',False,Statement.FreeIt);
  6449. AssertEquals('Correct return type',sdtInteger,Statement.ReturnType.DataType);
  6450. end;
  6451. { TTestGrantParser }
  6452. function TTestGrantParser.TestGrant(const ASource: String): TSQLGrantStatement;
  6453. begin
  6454. CreateParser(ASource);
  6455. FToFree:=Parser.Parse;
  6456. If not (FToFree is TSQLGrantStatement) then
  6457. Fail(Format('Wrong parse result class. Expected TSQLGrantStatement, got %s',[FTofree.ClassName]));
  6458. Result:=TSQLGrantStatement(Ftofree);
  6459. FSTatement:=Result;
  6460. AssertEquals('End of stream reached',tsqlEOF,Parser.CurrentToken);
  6461. end;
  6462. procedure TTestGrantParser.TestGrantError(const ASource: String);
  6463. begin
  6464. FErrSource:=ASource;
  6465. AssertException(ESQLParser,@TestParseError);
  6466. end;
  6467. procedure TTestGrantParser.TestSimple;
  6468. Var
  6469. t : TSQLTableGrantStatement;
  6470. G : TSQLUSerGrantee;
  6471. begin
  6472. TestGrant('GRANT SELECT ON A TO B');
  6473. T:=TSQLTableGrantStatement(CheckClass(Statement,TSQLTableGrantStatement));
  6474. AssertIdentifierName('Table name','A',T.TableName);
  6475. AssertEquals('One grantee', 1,T.Grantees.Count);
  6476. G:=TSQLUSerGrantee(CheckClass(T.Grantees[0],TSQLUSerGrantee));
  6477. AssertEquals('Grantee B','B',G.Name);
  6478. AssertEquals('One permission',1,T.Privileges.Count);
  6479. CheckClass(T.Privileges[0],TSQLSelectPrivilege);
  6480. AssertEquals('No grant option',False,T.GrantOption);
  6481. end;
  6482. procedure TTestGrantParser.Test2Operations;
  6483. Var
  6484. t : TSQLTableGrantStatement;
  6485. G : TSQLUSerGrantee;
  6486. begin
  6487. TestGrant('GRANT SELECT,INSERT ON A TO B');
  6488. T:=TSQLTableGrantStatement(CheckClass(Statement,TSQLTableGrantStatement));
  6489. AssertIdentifierName('Table name','A',T.TableName);
  6490. AssertEquals('One grantee', 1,T.Grantees.Count);
  6491. G:=TSQLUSerGrantee(CheckClass(T.Grantees[0],TSQLUSerGrantee));
  6492. AssertEquals('Grantee B','B',G.Name);
  6493. AssertEquals('Two permissions',2,T.Privileges.Count);
  6494. CheckClass(T.Privileges[0],TSQLSelectPrivilege);
  6495. CheckClass(T.Privileges[1],TSQLINSERTPrivilege);
  6496. AssertEquals('No grant option',False,T.GrantOption);
  6497. end;
  6498. procedure TTestGrantParser.TestDeletePrivilege;
  6499. Var
  6500. t : TSQLTableGrantStatement;
  6501. G : TSQLUSerGrantee;
  6502. begin
  6503. TestGrant('GRANT DELETE ON A TO B');
  6504. T:=TSQLTableGrantStatement(CheckClass(Statement,TSQLTableGrantStatement));
  6505. AssertIdentifierName('Table name','A',T.TableName);
  6506. AssertEquals('One grantee', 1,T.Grantees.Count);
  6507. G:=TSQLUSerGrantee(CheckClass(T.Grantees[0],TSQLUSerGrantee));
  6508. AssertEquals('Grantee B','B',G.Name);
  6509. AssertEquals('One permission',1,T.Privileges.Count);
  6510. CheckClass(T.Privileges[0],TSQLDeletePrivilege);
  6511. AssertEquals('No grant option',False,T.GrantOption);
  6512. end;
  6513. procedure TTestGrantParser.TestUpdatePrivilege;
  6514. Var
  6515. t : TSQLTableGrantStatement;
  6516. G : TSQLUSerGrantee;
  6517. begin
  6518. TestGrant('GRANT UPDATE ON A TO B');
  6519. T:=TSQLTableGrantStatement(CheckClass(Statement,TSQLTableGrantStatement));
  6520. AssertIdentifierName('Table name','A',T.TableName);
  6521. AssertEquals('One grantee', 1,T.Grantees.Count);
  6522. G:=TSQLUSerGrantee(CheckClass(T.Grantees[0],TSQLUSerGrantee));
  6523. AssertEquals('Grantee B','B',G.Name);
  6524. AssertEquals('One permission',1,T.Privileges.Count);
  6525. CheckClass(T.Privileges[0],TSQLUPDATEPrivilege);
  6526. AssertEquals('No grant option',False,T.GrantOption);
  6527. end;
  6528. procedure TTestGrantParser.TestInsertPrivilege;
  6529. Var
  6530. t : TSQLTableGrantStatement;
  6531. G : TSQLUSerGrantee;
  6532. begin
  6533. TestGrant('GRANT INSERT ON A TO B');
  6534. T:=TSQLTableGrantStatement(CheckClass(Statement,TSQLTableGrantStatement));
  6535. AssertIdentifierName('Table name','A',T.TableName);
  6536. AssertEquals('One grantee', 1,T.Grantees.Count);
  6537. G:=TSQLUSerGrantee(CheckClass(T.Grantees[0],TSQLUSerGrantee));
  6538. AssertEquals('Grantee B','B',G.Name);
  6539. AssertEquals('One permission',1,T.Privileges.Count);
  6540. CheckClass(T.Privileges[0],TSQLInsertPrivilege);
  6541. AssertEquals('No grant option',False,T.GrantOption);
  6542. end;
  6543. procedure TTestGrantParser.TestReferencePrivilege;
  6544. Var
  6545. t : TSQLTableGrantStatement;
  6546. G : TSQLUSerGrantee;
  6547. begin
  6548. TestGrant('GRANT REFERENCES ON A TO B');
  6549. T:=TSQLTableGrantStatement(CheckClass(Statement,TSQLTableGrantStatement));
  6550. AssertIdentifierName('Table name','A',T.TableName);
  6551. AssertEquals('One grantee', 1,T.Grantees.Count);
  6552. G:=TSQLUSerGrantee(CheckClass(T.Grantees[0],TSQLUSerGrantee));
  6553. AssertEquals('Grantee B','B',G.Name);
  6554. AssertEquals('One permission',1,T.Privileges.Count);
  6555. CheckClass(T.Privileges[0],TSQLReferencePrivilege);
  6556. AssertEquals('No grant option',False,T.GrantOption);
  6557. end;
  6558. procedure TTestGrantParser.TestAllPrivileges;
  6559. Var
  6560. t : TSQLTableGrantStatement;
  6561. G : TSQLUSerGrantee;
  6562. begin
  6563. TestGrant('GRANT ALL ON A TO B');
  6564. T:=TSQLTableGrantStatement(CheckClass(Statement,TSQLTableGrantStatement));
  6565. AssertIdentifierName('Table name','A',T.TableName);
  6566. AssertEquals('One grantee', 1,T.Grantees.Count);
  6567. G:=TSQLUSerGrantee(CheckClass(T.Grantees[0],TSQLUSerGrantee));
  6568. AssertEquals('Grantee B','B',G.Name);
  6569. AssertEquals('One permission',1,T.Privileges.Count);
  6570. CheckClass(T.Privileges[0],TSQLAllPrivilege);
  6571. AssertEquals('No grant option',False,T.GrantOption);
  6572. end;
  6573. procedure TTestGrantParser.TestAllPrivileges2;
  6574. Var
  6575. t : TSQLTableGrantStatement;
  6576. G : TSQLUSerGrantee;
  6577. begin
  6578. TestGrant('GRANT ALL PRIVILEGES ON A TO B');
  6579. T:=TSQLTableGrantStatement(CheckClass(Statement,TSQLTableGrantStatement));
  6580. AssertIdentifierName('Table name','A',T.TableName);
  6581. AssertEquals('One grantee', 1,T.Grantees.Count);
  6582. G:=TSQLUSerGrantee(CheckClass(T.Grantees[0],TSQLUSerGrantee));
  6583. AssertEquals('Grantee B','B',G.Name);
  6584. AssertEquals('One permission',1,T.Privileges.Count);
  6585. CheckClass(T.Privileges[0],TSQLAllPrivilege);
  6586. AssertEquals('No grant option',False,T.GrantOption);
  6587. end;
  6588. procedure TTestGrantParser.TestUpdateColPrivilege;
  6589. Var
  6590. t : TSQLTableGrantStatement;
  6591. G : TSQLUSerGrantee;
  6592. U : TSQLUPDATEPrivilege;
  6593. begin
  6594. TestGrant('GRANT UPDATE (C) ON A TO B');
  6595. T:=TSQLTableGrantStatement(CheckClass(Statement,TSQLTableGrantStatement));
  6596. AssertIdentifierName('Table name','A',T.TableName);
  6597. AssertEquals('One grantee', 1,T.Grantees.Count);
  6598. G:=TSQLUSerGrantee(CheckClass(T.Grantees[0],TSQLUSerGrantee));
  6599. AssertEquals('Grantee B','B',G.Name);
  6600. AssertEquals('One permission',1,T.Privileges.Count);
  6601. U:=TSQLUPDATEPrivilege(CheckClass(T.Privileges[0],TSQLUPDATEPrivilege));
  6602. AssertEquals('1 column',1,U.Columns.Count);
  6603. AssertIdentifierName('Column C','C',U.Columns[0]);
  6604. AssertEquals('No grant option',False,T.GrantOption);
  6605. end;
  6606. procedure TTestGrantParser.TestUpdate2ColsPrivilege;
  6607. Var
  6608. t : TSQLTableGrantStatement;
  6609. G : TSQLUSerGrantee;
  6610. U : TSQLUPDATEPrivilege;
  6611. begin
  6612. TestGrant('GRANT UPDATE (C,D) ON A TO B');
  6613. T:=TSQLTableGrantStatement(CheckClass(Statement,TSQLTableGrantStatement));
  6614. AssertIdentifierName('Table name','A',T.TableName);
  6615. AssertEquals('One grantee', 1,T.Grantees.Count);
  6616. G:=TSQLUSerGrantee(CheckClass(T.Grantees[0],TSQLUSerGrantee));
  6617. AssertEquals('Grantee B','B',G.Name);
  6618. AssertEquals('One permission',1,T.Privileges.Count);
  6619. U:=TSQLUPDATEPrivilege(CheckClass(T.Privileges[0],TSQLUPDATEPrivilege));
  6620. AssertEquals('2 column',2,U.Columns.Count);
  6621. AssertIdentifierName('Column C','C',U.Columns[0]);
  6622. AssertIdentifierName('Column D','D',U.Columns[1]);
  6623. AssertEquals('No grant option',False,T.GrantOption);
  6624. end;
  6625. procedure TTestGrantParser.TestReferenceColPrivilege;
  6626. Var
  6627. t : TSQLTableGrantStatement;
  6628. G : TSQLUSerGrantee;
  6629. U : TSQLReferencePrivilege;
  6630. begin
  6631. TestGrant('GRANT REFERENCES (C) ON A TO B');
  6632. T:=TSQLTableGrantStatement(CheckClass(Statement,TSQLTableGrantStatement));
  6633. AssertIdentifierName('Table name','A',T.TableName);
  6634. AssertEquals('One grantee', 1,T.Grantees.Count);
  6635. G:=TSQLUSerGrantee(CheckClass(T.Grantees[0],TSQLUSerGrantee));
  6636. AssertEquals('Grantee B','B',G.Name);
  6637. AssertEquals('One permission',1,T.Privileges.Count);
  6638. U:=TSQLReferencePrivilege(CheckClass(T.Privileges[0],TSQLReferencePrivilege));
  6639. AssertEquals('1 column',1,U.Columns.Count);
  6640. AssertIdentifierName('Column C','C',U.Columns[0]);
  6641. AssertEquals('No grant option',False,T.GrantOption);
  6642. end;
  6643. procedure TTestGrantParser.TestReference2ColsPrivilege;
  6644. Var
  6645. t : TSQLTableGrantStatement;
  6646. G : TSQLUSerGrantee;
  6647. U : TSQLReferencePrivilege;
  6648. begin
  6649. TestGrant('GRANT REFERENCES (C,D) ON A TO B');
  6650. T:=TSQLTableGrantStatement(CheckClass(Statement,TSQLTableGrantStatement));
  6651. AssertIdentifierName('Table name','A',T.TableName);
  6652. AssertEquals('One grantee', 1,T.Grantees.Count);
  6653. G:=TSQLUSerGrantee(CheckClass(T.Grantees[0],TSQLUSerGrantee));
  6654. AssertEquals('Grantee B','B',G.Name);
  6655. AssertEquals('One permission',1,T.Privileges.Count);
  6656. U:=TSQLReferencePrivilege(CheckClass(T.Privileges[0],TSQLReferencePrivilege));
  6657. AssertEquals('2 column',2,U.Columns.Count);
  6658. AssertIdentifierName('Column C','C',U.Columns[0]);
  6659. AssertIdentifierName('Column D','D',U.Columns[1]);
  6660. AssertEquals('No grant option',False,T.GrantOption);
  6661. end;
  6662. procedure TTestGrantParser.TestUserPrivilege;
  6663. Var
  6664. t : TSQLTableGrantStatement;
  6665. G : TSQLUSerGrantee;
  6666. begin
  6667. TestGrant('GRANT SELECT ON A TO USER B');
  6668. T:=TSQLTableGrantStatement(CheckClass(Statement,TSQLTableGrantStatement));
  6669. AssertIdentifierName('Table name','A',T.TableName);
  6670. AssertEquals('One grantee', 1,T.Grantees.Count);
  6671. G:=TSQLUSerGrantee(CheckClass(T.Grantees[0],TSQLUSerGrantee));
  6672. AssertEquals('Grantee B','B',G.Name);
  6673. AssertEquals('One permission',1,T.Privileges.Count);
  6674. CheckClass(T.Privileges[0],TSQLSelectPrivilege);
  6675. AssertEquals('No grant option',False,T.GrantOption);
  6676. end;
  6677. procedure TTestGrantParser.TestUserPrivilegeWithGrant;
  6678. Var
  6679. t : TSQLTableGrantStatement;
  6680. G : TSQLUSerGrantee;
  6681. begin
  6682. TestGrant('GRANT SELECT ON A TO USER B WITH GRANT OPTION');
  6683. T:=TSQLTableGrantStatement(CheckClass(Statement,TSQLTableGrantStatement));
  6684. AssertIdentifierName('Table name','A',T.TableName);
  6685. AssertEquals('One grantee', 1,T.Grantees.Count);
  6686. G:=TSQLUSerGrantee(CheckClass(T.Grantees[0],TSQLUSerGrantee));
  6687. AssertEquals('Grantee B','B',G.Name);
  6688. AssertEquals('One permission',1,T.Privileges.Count);
  6689. CheckClass(T.Privileges[0],TSQLSelectPrivilege);
  6690. AssertEquals('With grant option',True,T.GrantOption);
  6691. end;
  6692. procedure TTestGrantParser.TestGroupPrivilege;
  6693. Var
  6694. t : TSQLTableGrantStatement;
  6695. G : TSQLGroupGrantee;
  6696. begin
  6697. TestGrant('GRANT SELECT ON A TO GROUP B');
  6698. T:=TSQLTableGrantStatement(CheckClass(Statement,TSQLTableGrantStatement));
  6699. AssertIdentifierName('Table name','A',T.TableName);
  6700. AssertEquals('One grantee', 1,T.Grantees.Count);
  6701. G:=TSQLGroupGrantee(CheckClass(T.Grantees[0],TSQLGroupGrantee));
  6702. AssertEquals('Grantee B','B',G.Name);
  6703. AssertEquals('One permission',1,T.Privileges.Count);
  6704. CheckClass(T.Privileges[0],TSQLSelectPrivilege);
  6705. AssertEquals('No grant option',False,T.GrantOption);
  6706. end;
  6707. procedure TTestGrantParser.TestProcedurePrivilege;
  6708. Var
  6709. t : TSQLTableGrantStatement;
  6710. G : TSQLProcedureGrantee;
  6711. begin
  6712. TestGrant('GRANT SELECT ON A TO PROCEDURE B');
  6713. T:=TSQLTableGrantStatement(CheckClass(Statement,TSQLTableGrantStatement));
  6714. AssertIdentifierName('Table name','A',T.TableName);
  6715. AssertEquals('One grantee', 1,T.Grantees.Count);
  6716. G:=TSQLProcedureGrantee(CheckClass(T.Grantees[0],TSQLProcedureGrantee));
  6717. AssertEquals('Grantee B','B',G.Name);
  6718. AssertEquals('One permission',1,T.Privileges.Count);
  6719. CheckClass(T.Privileges[0],TSQLSelectPrivilege);
  6720. AssertEquals('No grant option',False,T.GrantOption);
  6721. end;
  6722. procedure TTestGrantParser.TestViewPrivilege;
  6723. Var
  6724. t : TSQLTableGrantStatement;
  6725. G : TSQLViewGrantee;
  6726. begin
  6727. TestGrant('GRANT SELECT ON A TO VIEW B');
  6728. T:=TSQLTableGrantStatement(CheckClass(Statement,TSQLTableGrantStatement));
  6729. AssertIdentifierName('Table name','A',T.TableName);
  6730. AssertEquals('One grantee', 1,T.Grantees.Count);
  6731. G:=TSQLViewGrantee(CheckClass(T.Grantees[0],TSQLViewGrantee));
  6732. AssertEquals('Grantee B','B',G.Name);
  6733. AssertEquals('One permission',1,T.Privileges.Count);
  6734. CheckClass(T.Privileges[0],TSQLSelectPrivilege);
  6735. AssertEquals('No grant option',False,T.GrantOption);
  6736. end;
  6737. procedure TTestGrantParser.TestTriggerPrivilege;
  6738. Var
  6739. t : TSQLTableGrantStatement;
  6740. G : TSQLTriggerGrantee;
  6741. begin
  6742. TestGrant('GRANT SELECT ON A TO TRIGGER B');
  6743. T:=TSQLTableGrantStatement(CheckClass(Statement,TSQLTableGrantStatement));
  6744. AssertIdentifierName('Table name','A',T.TableName);
  6745. AssertEquals('One grantee', 1,T.Grantees.Count);
  6746. G:=TSQLTriggerGrantee(CheckClass(T.Grantees[0],TSQLTriggerGrantee));
  6747. AssertEquals('Grantee B','B',G.Name);
  6748. AssertEquals('One permission',1,T.Privileges.Count);
  6749. CheckClass(T.Privileges[0],TSQLSelectPrivilege);
  6750. AssertEquals('No grant option',False,T.GrantOption);
  6751. end;
  6752. procedure TTestGrantParser.TestPublicPrivilege;
  6753. Var
  6754. t : TSQLTableGrantStatement;
  6755. begin
  6756. TestGrant('GRANT SELECT ON A TO PUBLIC');
  6757. T:=TSQLTableGrantStatement(CheckClass(Statement,TSQLTableGrantStatement));
  6758. AssertIdentifierName('Table name','A',T.TableName);
  6759. AssertEquals('One grantee', 1,T.Grantees.Count);
  6760. (CheckClass(T.Grantees[0],TSQLPublicGrantee));
  6761. AssertEquals('One permission',1,T.Privileges.Count);
  6762. CheckClass(T.Privileges[0],TSQLSelectPrivilege);
  6763. AssertEquals('No grant option',False,T.GrantOption);
  6764. end;
  6765. procedure TTestGrantParser.TestExecuteToUser;
  6766. Var
  6767. P : TSQLProcedureGrantStatement;
  6768. U : TSQLUserGrantee;
  6769. begin
  6770. TestGrant('GRANT EXECUTE ON PROCEDURE A TO B');
  6771. P:=TSQLProcedureGrantStatement(CheckClass(Statement,TSQLProcedureGrantStatement));
  6772. AssertIdentifierName('Procedure name','A',P.ProcedureName);
  6773. AssertEquals('One grantee', 1,P.Grantees.Count);
  6774. U:=TSQLUserGrantee(CheckClass(P.Grantees[0],TSQLUserGrantee));
  6775. AssertEquals('User name','B',U.Name);
  6776. AssertEquals('No grant option',False,P.GrantOption);
  6777. end;
  6778. procedure TTestGrantParser.TestExecuteToProcedure;
  6779. Var
  6780. P : TSQLProcedureGrantStatement;
  6781. U : TSQLProcedureGrantee;
  6782. begin
  6783. TestGrant('GRANT EXECUTE ON PROCEDURE A TO PROCEDURE B');
  6784. P:=TSQLProcedureGrantStatement(CheckClass(Statement,TSQLProcedureGrantStatement));
  6785. AssertIdentifierName('Procedure name','A',P.ProcedureName);
  6786. AssertEquals('One grantee', 1,P.Grantees.Count);
  6787. U:=TSQLProcedureGrantee(CheckClass(P.Grantees[0],TSQLProcedureGrantee));
  6788. AssertEquals('Procedure grantee name','B',U.Name);
  6789. AssertEquals('No grant option',False,P.GrantOption);
  6790. end;
  6791. procedure TTestGrantParser.TestRoleToUser;
  6792. Var
  6793. R : TSQLRoleGrantStatement;
  6794. U : TSQLUserGrantee;
  6795. begin
  6796. TestGrant('GRANT A TO B');
  6797. R:=TSQLRoleGrantStatement(CheckClass(Statement,TSQLRoleGrantStatement));
  6798. AssertEquals('One role', 1,R.Roles.Count);
  6799. AssertIdentifierName('Role name','A',R.Roles[0]);
  6800. AssertEquals('One grantee', 1,R.Grantees.Count);
  6801. U:=TSQLUserGrantee(CheckClass(R.Grantees[0],TSQLUserGrantee));
  6802. AssertEquals('Procedure grantee name','B',U.Name);
  6803. AssertEquals('No admin option',False,R.AdminOption);
  6804. end;
  6805. procedure TTestGrantParser.TestRoleToUserWithAdmin;
  6806. Var
  6807. R : TSQLRoleGrantStatement;
  6808. U : TSQLUserGrantee;
  6809. begin
  6810. TestGrant('GRANT A TO B WITH ADMIN OPTION');
  6811. R:=TSQLRoleGrantStatement(CheckClass(Statement,TSQLRoleGrantStatement));
  6812. AssertEquals('One role', 1,R.Roles.Count);
  6813. AssertIdentifierName('Role name','A',R.Roles[0]);
  6814. AssertEquals('One grantee', 1,R.Grantees.Count);
  6815. U:=TSQLUserGrantee(CheckClass(R.Grantees[0],TSQLUserGrantee));
  6816. AssertEquals('Procedure grantee name','B',U.Name);
  6817. AssertEquals('Admin option',True,R.AdminOption);
  6818. end;
  6819. procedure TTestGrantParser.TestRoleToPublic;
  6820. Var
  6821. R : TSQLRoleGrantStatement;
  6822. begin
  6823. TestGrant('GRANT A TO PUBLIC');
  6824. R:=TSQLRoleGrantStatement(CheckClass(Statement,TSQLRoleGrantStatement));
  6825. AssertEquals('One role', 1,R.Roles.Count);
  6826. AssertIdentifierName('Role name','A',R.Roles[0]);
  6827. AssertEquals('One grantee', 1,R.Grantees.Count);
  6828. CheckClass(R.Grantees[0],TSQLPublicGrantee);
  6829. AssertEquals('No admin option',False,R.AdminOption);
  6830. end;
  6831. procedure TTestGrantParser.Test2RolesToUser;
  6832. Var
  6833. R : TSQLRoleGrantStatement;
  6834. U : TSQLUserGrantee;
  6835. begin
  6836. TestGrant('GRANT A,C TO B');
  6837. R:=TSQLRoleGrantStatement(CheckClass(Statement,TSQLRoleGrantStatement));
  6838. AssertEquals('2 roles', 2,R.Roles.Count);
  6839. AssertIdentifierName('Role name','A',R.Roles[0]);
  6840. AssertIdentifierName('Role name','C',R.Roles[1]);
  6841. AssertEquals('One grantee', 1,R.Grantees.Count);
  6842. U:=TSQLUserGrantee(CheckClass(R.Grantees[0],TSQLUserGrantee));
  6843. AssertEquals('Procedure grantee name','B',U.Name);
  6844. AssertEquals('No admin option',False,R.AdminOption);
  6845. end;
  6846. { TTestRevokeParser }
  6847. function TTestRevokeParser.TestRevoke(const ASource: String): TSQLRevokeStatement;
  6848. begin
  6849. CreateParser(ASource);
  6850. FToFree:=Parser.Parse;
  6851. If not (FToFree is TSQLRevokeStatement) then
  6852. Fail(Format('Wrong parse result class. Expected TSQLRevokeStatement, got %s',[FTofree.ClassName]));
  6853. Result:=TSQLRevokeStatement(Ftofree);
  6854. FSTatement:=Result;
  6855. AssertEquals('End of stream reached',tsqlEOF,Parser.CurrentToken);
  6856. end;
  6857. procedure TTestRevokeParser.TestRevokeError(const ASource: String);
  6858. begin
  6859. FErrSource:=ASource;
  6860. AssertException(ESQLParser,@TestParseError);
  6861. end;
  6862. procedure TTestRevokeParser.TestSimple;
  6863. Var
  6864. t : TSQLTableRevokeStatement;
  6865. G : TSQLUSerGrantee;
  6866. begin
  6867. TestRevoke('Revoke SELECT ON A FROM B');
  6868. T:=TSQLTableRevokeStatement(CheckClass(Statement,TSQLTableRevokeStatement));
  6869. AssertIdentifierName('Table name','A',T.TableName);
  6870. AssertEquals('One Grantee', 1,T.Grantees.Count);
  6871. G:=TSQLUSerGrantee(CheckClass(T.Grantees[0],TSQLUSerGrantee));
  6872. AssertEquals('Grantee B','B',G.Name);
  6873. AssertEquals('One permission',1,T.Privileges.Count);
  6874. CheckClass(T.Privileges[0],TSQLSelectPrivilege);
  6875. AssertEquals('No Revoke option',False,T.GrantOption);
  6876. end;
  6877. procedure TTestRevokeParser.Test2Operations;
  6878. Var
  6879. t : TSQLTableRevokeStatement;
  6880. G : TSQLUSerGrantee;
  6881. begin
  6882. TestRevoke('Revoke SELECT,INSERT ON A FROM B');
  6883. T:=TSQLTableRevokeStatement(CheckClass(Statement,TSQLTableRevokeStatement));
  6884. AssertIdentifierName('Table name','A',T.TableName);
  6885. AssertEquals('One Grantee', 1,T.Grantees.Count);
  6886. G:=TSQLUSerGrantee(CheckClass(T.Grantees[0],TSQLUSerGrantee));
  6887. AssertEquals('Grantee B','B',G.Name);
  6888. AssertEquals('Two permissions',2,T.Privileges.Count);
  6889. CheckClass(T.Privileges[0],TSQLSelectPrivilege);
  6890. CheckClass(T.Privileges[1],TSQLINSERTPrivilege);
  6891. AssertEquals('No Revoke option',False,T.GrantOption);
  6892. end;
  6893. procedure TTestRevokeParser.TestDeletePrivilege;
  6894. Var
  6895. t : TSQLTableRevokeStatement;
  6896. G : TSQLUSerGrantee;
  6897. begin
  6898. TestRevoke('Revoke DELETE ON A FROM B');
  6899. T:=TSQLTableRevokeStatement(CheckClass(Statement,TSQLTableRevokeStatement));
  6900. AssertIdentifierName('Table name','A',T.TableName);
  6901. AssertEquals('One Grantee', 1,T.Grantees.Count);
  6902. G:=TSQLUSerGrantee(CheckClass(T.Grantees[0],TSQLUSerGrantee));
  6903. AssertEquals('Grantee B','B',G.Name);
  6904. AssertEquals('One permission',1,T.Privileges.Count);
  6905. CheckClass(T.Privileges[0],TSQLDeletePrivilege);
  6906. AssertEquals('No Revoke option',False,T.GrantOption);
  6907. end;
  6908. procedure TTestRevokeParser.TestUpdatePrivilege;
  6909. Var
  6910. t : TSQLTableRevokeStatement;
  6911. G : TSQLUSerGrantee;
  6912. begin
  6913. TestRevoke('Revoke UPDATE ON A FROM B');
  6914. T:=TSQLTableRevokeStatement(CheckClass(Statement,TSQLTableRevokeStatement));
  6915. AssertIdentifierName('Table name','A',T.TableName);
  6916. AssertEquals('One Grantee', 1,T.Grantees.Count);
  6917. G:=TSQLUSerGrantee(CheckClass(T.Grantees[0],TSQLUSerGrantee));
  6918. AssertEquals('Grantee B','B',G.Name);
  6919. AssertEquals('One permission',1,T.Privileges.Count);
  6920. CheckClass(T.Privileges[0],TSQLUPDATEPrivilege);
  6921. AssertEquals('No Revoke option',False,T.GrantOption);
  6922. end;
  6923. procedure TTestRevokeParser.TestInsertPrivilege;
  6924. Var
  6925. t : TSQLTableRevokeStatement;
  6926. G : TSQLUSerGrantee;
  6927. begin
  6928. TestRevoke('Revoke INSERT ON A FROM B');
  6929. T:=TSQLTableRevokeStatement(CheckClass(Statement,TSQLTableRevokeStatement));
  6930. AssertIdentifierName('Table name','A',T.TableName);
  6931. AssertEquals('One Grantee', 1,T.Grantees.Count);
  6932. G:=TSQLUSerGrantee(CheckClass(T.Grantees[0],TSQLUSerGrantee));
  6933. AssertEquals('Grantee B','B',G.Name);
  6934. AssertEquals('One permission',1,T.Privileges.Count);
  6935. CheckClass(T.Privileges[0],TSQLInsertPrivilege);
  6936. AssertEquals('No Revoke option',False,T.GrantOption);
  6937. end;
  6938. procedure TTestRevokeParser.TestReferencePrivilege;
  6939. Var
  6940. t : TSQLTableRevokeStatement;
  6941. G : TSQLUSerGrantee;
  6942. begin
  6943. TestRevoke('Revoke REFERENCES ON A FROM B');
  6944. T:=TSQLTableRevokeStatement(CheckClass(Statement,TSQLTableRevokeStatement));
  6945. AssertIdentifierName('Table name','A',T.TableName);
  6946. AssertEquals('One Grantee', 1,T.Grantees.Count);
  6947. G:=TSQLUSerGrantee(CheckClass(T.Grantees[0],TSQLUSerGrantee));
  6948. AssertEquals('Grantee B','B',G.Name);
  6949. AssertEquals('One permission',1,T.Privileges.Count);
  6950. CheckClass(T.Privileges[0],TSQLReferencePrivilege);
  6951. AssertEquals('No Revoke option',False,T.GrantOption);
  6952. end;
  6953. procedure TTestRevokeParser.TestAllPrivileges;
  6954. Var
  6955. t : TSQLTableRevokeStatement;
  6956. G : TSQLUSerGrantee;
  6957. begin
  6958. TestRevoke('Revoke ALL ON A FROM B');
  6959. T:=TSQLTableRevokeStatement(CheckClass(Statement,TSQLTableRevokeStatement));
  6960. AssertIdentifierName('Table name','A',T.TableName);
  6961. AssertEquals('One Grantee', 1,T.Grantees.Count);
  6962. G:=TSQLUSerGrantee(CheckClass(T.Grantees[0],TSQLUSerGrantee));
  6963. AssertEquals('Grantee B','B',G.Name);
  6964. AssertEquals('One permission',1,T.Privileges.Count);
  6965. CheckClass(T.Privileges[0],TSQLAllPrivilege);
  6966. AssertEquals('No Revoke option',False,T.GrantOption);
  6967. end;
  6968. procedure TTestRevokeParser.TestAllPrivileges2;
  6969. Var
  6970. t : TSQLTableRevokeStatement;
  6971. G : TSQLUSerGrantee;
  6972. begin
  6973. TestRevoke('Revoke ALL PRIVILEGES ON A FROM B');
  6974. T:=TSQLTableRevokeStatement(CheckClass(Statement,TSQLTableRevokeStatement));
  6975. AssertIdentifierName('Table name','A',T.TableName);
  6976. AssertEquals('One Grantee', 1,T.Grantees.Count);
  6977. G:=TSQLUSerGrantee(CheckClass(T.Grantees[0],TSQLUSerGrantee));
  6978. AssertEquals('Grantee B','B',G.Name);
  6979. AssertEquals('One permission',1,T.Privileges.Count);
  6980. CheckClass(T.Privileges[0],TSQLAllPrivilege);
  6981. AssertEquals('No Revoke option',False,T.GrantOption);
  6982. end;
  6983. procedure TTestRevokeParser.TestUpdateColPrivilege;
  6984. Var
  6985. t : TSQLTableRevokeStatement;
  6986. G : TSQLUSerGrantee;
  6987. U : TSQLUPDATEPrivilege;
  6988. begin
  6989. TestRevoke('Revoke UPDATE (C) ON A FROM B');
  6990. T:=TSQLTableRevokeStatement(CheckClass(Statement,TSQLTableRevokeStatement));
  6991. AssertIdentifierName('Table name','A',T.TableName);
  6992. AssertEquals('One Grantee', 1,T.Grantees.Count);
  6993. G:=TSQLUSerGrantee(CheckClass(T.Grantees[0],TSQLUSerGrantee));
  6994. AssertEquals('Grantee B','B',G.Name);
  6995. AssertEquals('One permission',1,T.Privileges.Count);
  6996. U:=TSQLUPDATEPrivilege(CheckClass(T.Privileges[0],TSQLUPDATEPrivilege));
  6997. AssertEquals('1 column',1,U.Columns.Count);
  6998. AssertIdentifierName('Column C','C',U.Columns[0]);
  6999. AssertEquals('No Revoke option',False,T.GrantOption);
  7000. end;
  7001. procedure TTestRevokeParser.TestUpdate2ColsPrivilege;
  7002. Var
  7003. t : TSQLTableRevokeStatement;
  7004. G : TSQLUSerGrantee;
  7005. U : TSQLUPDATEPrivilege;
  7006. begin
  7007. TestRevoke('Revoke UPDATE (C,D) ON A FROM B');
  7008. T:=TSQLTableRevokeStatement(CheckClass(Statement,TSQLTableRevokeStatement));
  7009. AssertIdentifierName('Table name','A',T.TableName);
  7010. AssertEquals('One Grantee', 1,T.Grantees.Count);
  7011. G:=TSQLUSerGrantee(CheckClass(T.Grantees[0],TSQLUSerGrantee));
  7012. AssertEquals('Grantee B','B',G.Name);
  7013. AssertEquals('One permission',1,T.Privileges.Count);
  7014. U:=TSQLUPDATEPrivilege(CheckClass(T.Privileges[0],TSQLUPDATEPrivilege));
  7015. AssertEquals('2 column',2,U.Columns.Count);
  7016. AssertIdentifierName('Column C','C',U.Columns[0]);
  7017. AssertIdentifierName('Column D','D',U.Columns[1]);
  7018. AssertEquals('No Revoke option',False,T.GrantOption);
  7019. end;
  7020. procedure TTestRevokeParser.TestReferenceColPrivilege;
  7021. Var
  7022. t : TSQLTableRevokeStatement;
  7023. G : TSQLUSerGrantee;
  7024. U : TSQLReferencePrivilege;
  7025. begin
  7026. TestRevoke('Revoke REFERENCES (C) ON A FROM B');
  7027. T:=TSQLTableRevokeStatement(CheckClass(Statement,TSQLTableRevokeStatement));
  7028. AssertIdentifierName('Table name','A',T.TableName);
  7029. AssertEquals('One Grantee', 1,T.Grantees.Count);
  7030. G:=TSQLUSerGrantee(CheckClass(T.Grantees[0],TSQLUSerGrantee));
  7031. AssertEquals('Grantee B','B',G.Name);
  7032. AssertEquals('One permission',1,T.Privileges.Count);
  7033. U:=TSQLReferencePrivilege(CheckClass(T.Privileges[0],TSQLReferencePrivilege));
  7034. AssertEquals('1 column',1,U.Columns.Count);
  7035. AssertIdentifierName('Column C','C',U.Columns[0]);
  7036. AssertEquals('No Revoke option',False,T.GrantOption);
  7037. end;
  7038. procedure TTestRevokeParser.TestReference2ColsPrivilege;
  7039. Var
  7040. t : TSQLTableRevokeStatement;
  7041. G : TSQLUSerGrantee;
  7042. U : TSQLReferencePrivilege;
  7043. begin
  7044. TestRevoke('Revoke REFERENCES (C,D) ON A FROM B');
  7045. T:=TSQLTableRevokeStatement(CheckClass(Statement,TSQLTableRevokeStatement));
  7046. AssertIdentifierName('Table name','A',T.TableName);
  7047. AssertEquals('One Grantee', 1,T.Grantees.Count);
  7048. G:=TSQLUSerGrantee(CheckClass(T.Grantees[0],TSQLUSerGrantee));
  7049. AssertEquals('Grantee B','B',G.Name);
  7050. AssertEquals('One permission',1,T.Privileges.Count);
  7051. U:=TSQLReferencePrivilege(CheckClass(T.Privileges[0],TSQLReferencePrivilege));
  7052. AssertEquals('2 column',2,U.Columns.Count);
  7053. AssertIdentifierName('Column C','C',U.Columns[0]);
  7054. AssertIdentifierName('Column D','D',U.Columns[1]);
  7055. AssertEquals('No Revoke option',False,T.GrantOption);
  7056. end;
  7057. procedure TTestRevokeParser.TestUserPrivilege;
  7058. Var
  7059. t : TSQLTableRevokeStatement;
  7060. G : TSQLUSerGrantee;
  7061. begin
  7062. TestRevoke('Revoke SELECT ON A FROM USER B');
  7063. T:=TSQLTableRevokeStatement(CheckClass(Statement,TSQLTableRevokeStatement));
  7064. AssertIdentifierName('Table name','A',T.TableName);
  7065. AssertEquals('One Grantee', 1,T.Grantees.Count);
  7066. G:=TSQLUSerGrantee(CheckClass(T.Grantees[0],TSQLUSerGrantee));
  7067. AssertEquals('Grantee B','B',G.Name);
  7068. AssertEquals('One permission',1,T.Privileges.Count);
  7069. CheckClass(T.Privileges[0],TSQLSelectPrivilege);
  7070. AssertEquals('No Revoke option',False,T.GrantOption);
  7071. end;
  7072. procedure TTestRevokeParser.TestUserPrivilegeWithRevoke;
  7073. Var
  7074. t : TSQLTableRevokeStatement;
  7075. G : TSQLUSerGrantee;
  7076. begin
  7077. TestRevoke('Revoke GRANT OPTION FOR SELECT ON A FROM USER B');
  7078. T:=TSQLTableRevokeStatement(CheckClass(Statement,TSQLTableRevokeStatement));
  7079. AssertIdentifierName('Table name','A',T.TableName);
  7080. AssertEquals('One Grantee', 1,T.Grantees.Count);
  7081. G:=TSQLUSerGrantee(CheckClass(T.Grantees[0],TSQLUSerGrantee));
  7082. AssertEquals('Grantee B','B',G.Name);
  7083. AssertEquals('One permission',1,T.Privileges.Count);
  7084. CheckClass(T.Privileges[0],TSQLSelectPrivilege);
  7085. AssertEquals('With Revoke option',True,T.GrantOption);
  7086. end;
  7087. procedure TTestRevokeParser.TestGroupPrivilege;
  7088. Var
  7089. t : TSQLTableRevokeStatement;
  7090. G : TSQLGroupGrantee;
  7091. begin
  7092. TestRevoke('Revoke SELECT ON A FROM GROUP B');
  7093. T:=TSQLTableRevokeStatement(CheckClass(Statement,TSQLTableRevokeStatement));
  7094. AssertIdentifierName('Table name','A',T.TableName);
  7095. AssertEquals('One Grantee', 1,T.Grantees.Count);
  7096. G:=TSQLGroupGrantee(CheckClass(T.Grantees[0],TSQLGroupGrantee));
  7097. AssertEquals('Grantee B','B',G.Name);
  7098. AssertEquals('One permission',1,T.Privileges.Count);
  7099. CheckClass(T.Privileges[0],TSQLSelectPrivilege);
  7100. AssertEquals('No Revoke option',False,T.GrantOption);
  7101. end;
  7102. procedure TTestRevokeParser.TestProcedurePrivilege;
  7103. Var
  7104. t : TSQLTableRevokeStatement;
  7105. G : TSQLProcedureGrantee;
  7106. begin
  7107. TestRevoke('Revoke SELECT ON A FROM PROCEDURE B');
  7108. T:=TSQLTableRevokeStatement(CheckClass(Statement,TSQLTableRevokeStatement));
  7109. AssertIdentifierName('Table name','A',T.TableName);
  7110. AssertEquals('One Grantee', 1,T.Grantees.Count);
  7111. G:=TSQLProcedureGrantee(CheckClass(T.Grantees[0],TSQLProcedureGrantee));
  7112. AssertEquals('Grantee B','B',G.Name);
  7113. AssertEquals('One permission',1,T.Privileges.Count);
  7114. CheckClass(T.Privileges[0],TSQLSelectPrivilege);
  7115. AssertEquals('No Revoke option',False,T.GrantOption);
  7116. end;
  7117. procedure TTestRevokeParser.TestViewPrivilege;
  7118. Var
  7119. t : TSQLTableRevokeStatement;
  7120. G : TSQLViewGrantee;
  7121. begin
  7122. TestRevoke('Revoke SELECT ON A FROM VIEW B');
  7123. T:=TSQLTableRevokeStatement(CheckClass(Statement,TSQLTableRevokeStatement));
  7124. AssertIdentifierName('Table name','A',T.TableName);
  7125. AssertEquals('One Grantee', 1,T.Grantees.Count);
  7126. G:=TSQLViewGrantee(CheckClass(T.Grantees[0],TSQLViewGrantee));
  7127. AssertEquals('Grantee B','B',G.Name);
  7128. AssertEquals('One permission',1,T.Privileges.Count);
  7129. CheckClass(T.Privileges[0],TSQLSelectPrivilege);
  7130. AssertEquals('No Revoke option',False,T.GrantOption);
  7131. end;
  7132. procedure TTestRevokeParser.TestTriggerPrivilege;
  7133. Var
  7134. t : TSQLTableRevokeStatement;
  7135. G : TSQLTriggerGrantee;
  7136. begin
  7137. TestRevoke('Revoke SELECT ON A FROM TRIGGER B');
  7138. T:=TSQLTableRevokeStatement(CheckClass(Statement,TSQLTableRevokeStatement));
  7139. AssertIdentifierName('Table name','A',T.TableName);
  7140. AssertEquals('One Grantee', 1,T.Grantees.Count);
  7141. G:=TSQLTriggerGrantee(CheckClass(T.Grantees[0],TSQLTriggerGrantee));
  7142. AssertEquals('Grantee B','B',G.Name);
  7143. AssertEquals('One permission',1,T.Privileges.Count);
  7144. CheckClass(T.Privileges[0],TSQLSelectPrivilege);
  7145. AssertEquals('No Revoke option',False,T.GrantOption);
  7146. end;
  7147. procedure TTestRevokeParser.TestPublicPrivilege;
  7148. Var
  7149. t : TSQLTableRevokeStatement;
  7150. begin
  7151. TestRevoke('Revoke SELECT ON A FROM PUBLIC');
  7152. T:=TSQLTableRevokeStatement(CheckClass(Statement,TSQLTableRevokeStatement));
  7153. AssertIdentifierName('Table name','A',T.TableName);
  7154. AssertEquals('One Grantee', 1,T.Grantees.Count);
  7155. (CheckClass(T.Grantees[0],TSQLPublicGrantee));
  7156. AssertEquals('One permission',1,T.Privileges.Count);
  7157. CheckClass(T.Privileges[0],TSQLSelectPrivilege);
  7158. AssertEquals('No Revoke option',False,T.GrantOption);
  7159. end;
  7160. procedure TTestRevokeParser.TestExecuteToUser;
  7161. Var
  7162. P : TSQLProcedureRevokeStatement;
  7163. U : TSQLUserGrantee;
  7164. begin
  7165. TestRevoke('Revoke EXECUTE ON PROCEDURE A FROM B');
  7166. P:=TSQLProcedureRevokeStatement(CheckClass(Statement,TSQLProcedureRevokeStatement));
  7167. AssertIdentifierName('Procedure name','A',P.ProcedureName);
  7168. AssertEquals('One Grantee', 1,P.Grantees.Count);
  7169. U:=TSQLUserGrantee(CheckClass(P.Grantees[0],TSQLUserGrantee));
  7170. AssertEquals('User name','B',U.Name);
  7171. AssertEquals('No Revoke option',False,P.GrantOption);
  7172. end;
  7173. procedure TTestRevokeParser.TestExecuteToProcedure;
  7174. Var
  7175. P : TSQLProcedureRevokeStatement;
  7176. U : TSQLProcedureGrantee;
  7177. begin
  7178. TestRevoke('Revoke EXECUTE ON PROCEDURE A FROM PROCEDURE B');
  7179. P:=TSQLProcedureRevokeStatement(CheckClass(Statement,TSQLProcedureRevokeStatement));
  7180. AssertIdentifierName('Procedure name','A',P.ProcedureName);
  7181. AssertEquals('One Grantee', 1,P.Grantees.Count);
  7182. U:=TSQLProcedureGrantee(CheckClass(P.Grantees[0],TSQLProcedureGrantee));
  7183. AssertEquals('Procedure Grantee name','B',U.Name);
  7184. AssertEquals('No Revoke option',False,P.GrantOption);
  7185. end;
  7186. procedure TTestRevokeParser.TestRoleToUser;
  7187. Var
  7188. R : TSQLRoleRevokeStatement;
  7189. U : TSQLUserGrantee;
  7190. begin
  7191. TestRevoke('Revoke A FROM B');
  7192. R:=TSQLRoleRevokeStatement(CheckClass(Statement,TSQLRoleRevokeStatement));
  7193. AssertEquals('One role', 1,R.Roles.Count);
  7194. AssertIdentifierName('Role name','A',R.Roles[0]);
  7195. AssertEquals('One Grantee', 1,R.Grantees.Count);
  7196. U:=TSQLUserGrantee(CheckClass(R.Grantees[0],TSQLUserGrantee));
  7197. AssertEquals('Procedure Grantee name','B',U.Name);
  7198. AssertEquals('No admin option',False,R.AdminOption);
  7199. end;
  7200. procedure TTestRevokeParser.TestRoleToPublic;
  7201. Var
  7202. R : TSQLRoleRevokeStatement;
  7203. begin
  7204. TestRevoke('Revoke A FROM PUBLIC');
  7205. R:=TSQLRoleRevokeStatement(CheckClass(Statement,TSQLRoleRevokeStatement));
  7206. AssertEquals('One role', 1,R.Roles.Count);
  7207. AssertIdentifierName('Role name','A',R.Roles[0]);
  7208. AssertEquals('One Grantee', 1,R.Grantees.Count);
  7209. CheckClass(R.Grantees[0],TSQLPublicGrantee);
  7210. AssertEquals('No admin option',False,R.AdminOption);
  7211. end;
  7212. procedure TTestRevokeParser.Test2RolesToUser;
  7213. Var
  7214. R : TSQLRoleRevokeStatement;
  7215. U : TSQLUserGrantee;
  7216. begin
  7217. TestRevoke('Revoke A,C FROM B');
  7218. R:=TSQLRoleRevokeStatement(CheckClass(Statement,TSQLRoleRevokeStatement));
  7219. AssertEquals('2 roles', 2,R.Roles.Count);
  7220. AssertIdentifierName('Role name','A',R.Roles[0]);
  7221. AssertIdentifierName('Role name','C',R.Roles[1]);
  7222. AssertEquals('One Grantee', 1,R.Grantees.Count);
  7223. U:=TSQLUserGrantee(CheckClass(R.Grantees[0],TSQLUserGrantee));
  7224. AssertEquals('Procedure Grantee name','B',U.Name);
  7225. AssertEquals('No admin option',False,R.AdminOption);
  7226. end;
  7227. initialization
  7228. RegisterTests([TTestDropParser,
  7229. TTestGeneratorParser,
  7230. TTestRoleParser,
  7231. TTestTypeParser,
  7232. TTestCheckParser,
  7233. TTestDomainParser,
  7234. TTestExceptionParser,
  7235. TTestIndexParser,
  7236. TTestTableParser,
  7237. TTestDeleteParser,
  7238. TTestUpdateParser,
  7239. TTestInsertParser,
  7240. TTestSelectParser,
  7241. TTestRollbackParser,
  7242. TTestCommitParser,
  7243. TTestExecuteProcedureParser,
  7244. TTestConnectParser,
  7245. TTestCreateDatabaseParser,
  7246. TTestAlterDatabaseParser,
  7247. TTestCreateViewParser,
  7248. TTestCreateShadowParser,
  7249. TTestProcedureStatement,
  7250. TTestCreateProcedureParser,
  7251. TTestCreateTriggerParser,
  7252. TTestDeclareExternalFunctionParser,
  7253. TTestGrantParser,
  7254. TTestRevokeParser,
  7255. TTestGlobalParser,
  7256. TTestSetTermParser]);
  7257. end.