tcparser.pas 282 KB

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