ebook img

Extending Design by Contract for Aspect-Oriented Programming PDF

0.18 MB·English
Save to my drive
Quick download
Download
Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.

Preview Extending Design by Contract for Aspect-Oriented Programming

Extending Design by Contract for Aspect-Oriented Programming David H. Lorenz Therapon Skotiniotis Technical Report NU-CCIS-04-14 College of Computer & Information Science Northeastern University Boston, Massachusetts 02115 USA { lorenz, skotthe }@ccs.neu.edu 5 0 0 2 ABSTRACT DbC for OOP also validates logical implications between super- DesignbyContract(DbC)andruntimeenforcementofprogramas- typeassertionsandsubtypesassertionsonmethods[9]:anoverrid- n sertionsenablestheconstructionof morerobust software. Italso ingmethodmustbeabehavioralsubstitute[18]foritsoverridden a J enablestheassignmentofblameinerrorreporting. Unfortunately, counterpart. In comparison, DbC for AOPmust validate that the there is no support for runtime contract enforcement and blame methodwithanadviceisabehavioralsubstituteforitsadvice-less 4 assignment for Aspect-Oriented Programming (AOP). Extending counterpart. 2 DbC toalsocover aspectsbringsforwardaplethoraof issuesre- latedtothecorrectorderofassertionvalidation.Weshowthatthere Thesedifferencesbringsaboutseveralissues: ] E isnogenerallycorrectexecutionsequenceofobjectassertionsand S aspect assertions. A further classification of aspects as agnostic, (i) At what point during the execution of theprogram should . obedient,orrebelliousdefinestheorderofassertionvalidationthat s eachkindofassertionbechecked? needs to be followed. We describe the application of this classi- c [ fication in a prototyped DbC tool for AOP named CONA, where (ii) Shouldtherebeaconnectionbetweenassertionsonmethods aspectsareusedforimplementingcontracts,andcontractsareused andassertionsonadviceandhowshouldthatbeenforcedat 1 forenforcingassertionsonaspects. runtime? v 0 (iii) Howisblameassignmentaffected? 7 1. INTRODUCTION 0 1 DesignbyContract(DbC)[22]isamethodologyforsoftwarecon- InthispaperweextendtheclassicDbCruntimecontractenforce- 0 structionthatisbasedonruntimeenforcementofassertions. Sev- mentmechanismtocoverAspectJ’s[20,12,3]advicedefinitions. 5 eralobject-orientedprogramming(OOP)languagesfollowtheEif- Weconcentrateontheimpactoftherelativeinterleavingorderof 0 fel [23] example in providing support for DbC (including, e.g., objectcontractcheckingandaspectcontractchecking. / Blue[14]andSather[24]). Unfortunately,noaspect-orientedpro- s c gramming(AOP)languageofferssupportforDbC.Thispaperex- InSection2,weshowthatthereisnogenerallyapplicablecorrect : tendsDbCforcontrollingalsotheinteractionsbetweenadviceand order. InSection3,wedevelopaclassificationofaspectsaccord- v methods[25],aneedthatisevidentinanynon-trivialAOPappli- ing to the way they influence object contracts. We classify each i X cationdevelopment[11]. aspectaseitheragnostic,obedient,orrebellious,andshowthatthe membershipofanaspectinoneofthedefinedcategoriesimpliesa r a Whileruntimecontractenforcementandblameassignmentforob- particularorder.Basedonthisclassification,theexecutionorderof jectsiswellunderstood,itisunclearhowDbCextendstoaspects. methodinvocation(anditsadviceandassertions)changes,inorder InDbCforOOP,assertionsareenforcedduringmethodinvocation; toproperlyassignblameforanycontractviolationsthatmayoccur. afailureclearlyimplicatesoneoftwodistinctobjects,thecalleror the callee. In DbC for AOP, there are two kinds of entities (ob- Enforcing contracts via aspects is also an application area of as- jectsandaspects),twodifferentkindsofassertions(assertionsfor pectsthatservesasanillustrationfortheneedtodifferentiatebe- objects and assertions for aspects), and no implicit caller (for an tweenagnostic,obedient,andrebelliousaspects. InSection4,we aspect’sadvice). presentCONA[21,29,28,26],atoolfortheprovisionandenforce- mentofDbCinbothOOPandAOP. 2. MOTIVATINGEXAMPLE Considerasoftwaresystemforanonlinebookstore(Figure1)with officesintheUSA,Greece,andIsrael. Abooksaletransactionre- quiresanon-emptyISBNnumber(pre-conditionofOnlineBook- store.sale). The sale completes by providing a book that either matches the requested ISBN number or has the same title (post- conditionofOnlineBookstore.sale)butpossiblyadifferentISBN. Thepost-conditioninOnlineBookstore.salepermitstosubstitute 1 OnlineBookstore +sale(ISBN):Book @pre{ISBN!=null} @post{result.ISBN.equals(ISBN) kISBN.getTitle()=result.getTitle()} USBranch ILBranch +sale(ISBN):Book +sale(ISBN):Book @pre{ISBN!=null} @pre{ISBN!=null} @post{result.ISBN.equals(ISBN) @post{result.ISBN.equals(ISBN) k(result.ISBN!=ISBN&& k(result.ISBN!=ISBN&& result.getTitle()=bookDB.getTitle()&& result.getTitle()=bookDB.getTitle()&& result.getBookType()=HC&& result.getBookType()=HC&& bookDB.getBookType(ISBN)=PB&& bookDB.getBookType(ISBN)=PB&& result.getShipping()<20)} result.tCost()−Calc.tCost(ISBN)<10)} GRBranch +sale(ISBN):Book @pre{ISBN!=null} @post{result.ISBN.equals(ISBN) kISBN.getTitle()=result.getTitle()} Figure1: TheonlinebookstorehasofficesinUSA,Greece,andIsrael. Eachsitehasdifferenttaxes(Sales,VAT)andalsodifferent shippingagencies.saleisoverwritten,however,thecontractsassociatedwitheachmethodimplementationmakethethreesubclasses properbehavioralsubtypesofOnlineBookstore. therequestedbookwithadifferenteditionofthebook1(e.g.,apa- implemented) are used. Sincean aspect may observe or alter in- perback(PB)versioninsteadofahardcover(HC)version,orvice formationbefore,after,oraroundamethod’scall/execution,auser versa). aspect’sadvicemight: ConcretesubclassesofOnlineBookstorespecializesaletoreflect • Break a method’s pre-condition even when the client calls thepolicyineffectineachofthethreedifferentcountries.Specifi- themethodcorrectly. cally, • Break a method’s post-condition even when the method’s pre-andpost-conditionwherefulfilledbythemethod’sim- • IntheUSA,anorderforapaperbackversionofabookthat plementation. isnotavailableinthebookstoremaybefulfilledwithahard- coverversionofthebookaslongastheshippingcostsforthe • Correctacalltoamethodmthatoriginallyviolatedm’spre- hardcoverversiondoesnotexceedtheamountof20Dollars. condition. • InGreece,anorderforabookthatisnotin-stockbutanother • Correctapreviously erroneousimplementation thatdidnot version(paperback or hardcover) isavailableisfulfilledby fulfillitspost-condition. providingthatversioninstead. • Addextrabehaviortoamethod’simplementationwithoutal- teringthesetofstatesacceptedbythepre-andpost-condition • InIsrael,iftherequestedbookisapaperbackbutthebook- assertions,i.e.,provideadifferentmappingforthesamein- store has only the hardcover version, then the hardcover is providedaslongasthedifferenceinthetotalcost(bookprice putandoutputvaluesetsofthemethod. plusshipping)islessthan10Shekels. • Addextrabehaviorbyextendingthemethod’sspecification (pre-and/orpost-conditions). Thepost-conditiononthespecializedimplementationsofsalecap- • Monitor a method’s execution by collecting information or turethecorrespondingcountry’spolicy,whichneedstobechecked checkingcertainsystempropertieswithoutaffectingthebe- atruntime. haviorofthemethod. Intermsofcontracts(transactions)theroleofprovider(server)is played by the online bookstore software. The consumer (client) Theorderofexecutionamongstaspectadvice,pre-andpost-condition roleisplayedbythecustomerthatusestheonlinebookstoresoft- validation,andmethodexecutiondetermineswhichoneoftheabove ware. situationsoccur. Forexample,behavioralextensionviaaspectad- viceshouldonlybeallowedwhenaspectadviceisexecutedbefore amethod’spre-conditionorpost-conditionvalidation. 2.1 Contracts inthe Presence ofAspects Interestingissuesariseinthesituationswhereuseraspectsarepresent Consider (the addition of an aspect that will implement) an in- in the system where contracts (regardless of how they are being crease of 10% in shipping cost on hardcover books (Listing 1). 1Weassumethattwobookswiththesametitleareeitherthesame ShippingCostisaddedtothesystemandattachedtosalemethod ordifferenteditionsofthesamebook. Thatis, theredonotexist callswithanafteradviceholdingtherelevantcodefortheenforce- twobooksofdifferentcontentswiththesametitleinthebookstore. ment of the extra cost. Focusing on sale method calls, it is not 2 post-conditioncheckisenforcedthenthedifferenceintotalcostis Listing1: ShippingCostaspectaddingthe10%extrashipping 0Shekelsandthesalecangothrough. costonhardcovereditions. 1 aspectShippingCost{ One may resort to a conservative approach in which a method’s 2 pointcutHDSales(ISBNisbn):call(∗OnlineBookstore.sales(..) pre-condition is checked twice: once before the advice and once )&&args(isbn); before themethod (execution order C inTable1). However, that 3 wouldrestricttheapplicableaspects,therebycompromisingobliv- after(ISBNisbn)returning(Bookitem): 4 iousness[8]. 5 HDSales(isbn){ 6 item.setShippingCost(item.getShippingCost()∗1.1); item.calculateTotalCost(); 3. A CLASSIFICATIONOF ASPECTS FOR 7 8 } DBC 9 } Aspectscanbeused: (i) toenforcepropertieswithoutalteringthebehavioroftheun- obviouswhatexecutionsequenceamongstpre-andpost-condition derlyingsystem(e.g., loggingtheonlinebookstoresystem, validation,aspectadviceandmethodexecutionshouldbefollowed. checkingtheonlinebookstorecodingstyle[17],implement- Threepossibilities(Table1)arepossibleandwewillexamineeach ingtheDbCassertionsfoundinFigure1[cf.Section4]. oneinturnwithinthecontextoftheonlinebookstoreexample. (ii) toallowforextensionstothebehavioroftheunderlyingsys- Assuminganexecutionpolicywhereuseraspectsareexecutedbe- tem,(e.g.,allowingforextracharges/discountsontheonline fore pre-conditions and after post-condition are enforced (execu- bookstore). tion order A in Table 1), clients to both the USBranch and IL- Branchmaybechargedmorethanwhatwasagreed.Althoughthe clienthasmaintainedtheoriginallyagreeduponcontract,thefinal Thetwodifferentusesofaspectsinthepresenceofcontractsim- outcomebreakstheclientsexpectationsblamingtheprovider. posescertainrestrictionsontheirexecutionorder. Furthermore,it mayresultinerroneousblameassignmentscomplicatingerrorde- Theshippingcostincreaseintroducedviatheaspect canresultto tectionandresolution. shipmentswherethetotalshippingcostwillbemorethan$20and atotalcostthatismorethan10Shekels. Fromtheclientspointof Thechoiceofwhichinterleavingexecutionorder(Table1)toen- view,itisclearlyanerroroftheonlinebookstoresincetheagreed forcealsodependsonthemechanismofassigningblameincases policy for replacing a paperback edition was not followed.2 At of violation. Standard DbC mechanisms are ignorant of aspects. thesametimethecorrespondingbrancheshaveassurances(sale’s Blameassignmentmustthereforebeextendedtodealwithaspects post-condition) that the replacement policy was honored. DbC asentitiesthatcanbeassignedblame.Also,whatisbeingviolated mechanisms fail to correctly assign blame in the presence of as- has to be redefined in order to take into account the intention of pects,misguidingdevelopersandincreasingthetimespendonbug codefoundinaspectdefinitions. detectionandcorrection. Itisclearthatthepartythatisactuallyat faulthereistheaspect.Onecanconcludethattheaspectisatfault Theabilitytodefineanaspect’sintentionsthroughacleardeclar- onlyafterobservingallthreeentities,theirexecutionsequenceand ativespecificationaswellastheruntimevalidationoftheseinten- theirinteractions. tions is crucial in error detection, error resolution and reasoning aboutaspect-orientedprograms. Weidentifythreeintentionalcat- However,anaspectcanalsobeusedtobringabouttheexactoppo- egoriesofaspects:namely,agnostic,obedient,andrebellious. siteeffect.Anaspectcaninterveneafterthereturnofamethodthat originallyreturnedafaultyresultwhichviolatedthepost-condition 3.1 AgnosticAspects andmodifytheresultinsuchawaysothatnowthepost-condition is not violated. The execution interleaving would have to allow Agnostic aspects are aspects that do not affect a method’s asser- such aspectstointervenebeforetheruntimecheck foramethods tionsinanyway.Agnosticaspectsare“sandwiched”withtheorig- post-condition(executionorderBinTable1). Thesesituationsare inal method’s pre- and post-conditions. From the perspective of examplesofextensions/fixesthroughaspects. thecallersofthemethod,themethodwiththeadvice(asonbody) hasthesameassertionsastheoriginal methodbody. Inaddition, Inthecaseoftheonlinebookstore,supposethata20%markdown assertionsdonotchangefromthemethod’sperspectiveeither. isineffectforallhardcovereditions.ConsideracustomerinIsrael orderingabookusingtheISBNofthepaperbackedition.Suppose 3.1.1 ExecutionOrder the paperback edition costs 80 Shekels and the hardcover edition Thelanguageimposesthefollowingexecutionsequenceinthecase costs100Shekels. Thebookstoredoesnothaveanycopiesofthe ofagnosticaspects(executionorderC): paperback editionandprovidesthehardcover editionofthebook instead.Beforeapplyingthe20%markdownonthehardcoveredi- mpre;αbpreef ;α;αbpeofst ;mpre;m;mpost ; tion,thepost-conditionoftheILBranchdisallowstheswitchfrom ;αafter ;α;αafter ;m pre post post paperbacktohardcoversincethedifferenceincostismorethan10 Where Shekels. Howeveriftheaspectisallowedtointervenebeforethe 2In fact an OOP runtime contract enforcement mechanism will blame the corresponding bookstore branch since it does not take • αbpreef denotestothepre-conditionoftheaspect’s(α)before intoaccountaspectsandtheirspecification. advice 3 Policy ExecutionInterleaving ExecOrderA α ; m ; m ; m ; α pre post ExecOrderB m ; α ; m ; α ; m pre post ExecOrderC m ; α ; m ; m ; m ; α ; m pre pre post post Table1:Threealternativepoliciesofinterleavingexecution(formlefttoright)ofcontractscheckingpre-andpost-conditions(m pre andm respectively)withadvicefromanaspect(α). post • αbef denotestothepost-conditionoftheaspect’s(α)before there should be no change in the method’s behavior and specifi- post advice cation. Furthermore, thereturn values of theafter advice arethe returnvaluesofthemethodcallasawholeandthusthemethod’s • mpredenotestothemethod’s(m)pre-condition post-conditionmustalsohold. • mpostdenotestothemethod’s(m)post-condition 3.2 Obedient Aspects • αafter denotes tothepre-condition of theaspect’s(α) after pre Anotherformofextensiontothebasesystemisonewherethesetof advice inputandoutputstatesremainsthesamebutthemappingofinput • αafter denotestothepost-conditionoftheaspect’s(α)after tooutput valueschanges. Inthesesituationstheaspectwithsuch post advice anintendedextensioniscategorizedasanobedientaspect. Obedient aspectsareaspectsusedtoprovideextrabehaviorwith- Thisexecutionsequencemakessurethattheoriginalmethod’spre- outchangingthemethod’spre-andpost-conditions,i.e.,obedient and post-condition is validated both before advice execution and aspectsjustprovideadifferentmappingfromthesameinputtothe afteradviceexecution. same output value setsof themethod. Fromthe perspective of a callerofthemethod,themethodwiththeadvicehasthesameas- 3.1.2 BlameAssignment sertionsastheoriginalmethodhad. Runtimeassertionvalidationandblameassignmentforagnosticas- pectsisdescribedinTable2.Ontopofcheckingforeachindividual 3.2.1 ExecutionOrder assertionatruntimeextraimplicationsbetweenassertionsareval- idated to guarantee proper execution flow between aspect advice Declaringanobedientaspectimposesthefollowingexecutionse- and method implementation. The method’s pre-condition has to quence(executionorderB): implythebeforeadvicepre-conditionmakingsurethattheaspect m ;αbef ;α;αbef ;m;αafter ;α;αafter ;m developer took into account the valid start states of the method. pre pre post pre post post Furthermore, beforeadvicepost-conditionhastoimplythemeth- Addinganobedientaspectdoesnotalterthepre-andpost-conditions ods pre-condition. Since no alteration of behavior is allowed in ofthemethodastheyareknowntotherestofthesystem.Thefirst agnostic aspects execution of the method’s implementation must assertionvalidationisstilltheoriginalmethod’spre-conditionand startinavalidstatesatisfyingthemethodspre-condition. thelastassertionvalidationistheoriginalmethod’spost-condition. Similarly,themethod’spost-conditionmustimplytheafteradvice pre-condition. Thisisagaintheresponsibilityoftheaspectdevel- 3.2.2 BlameAssignment operwhoisrequiredtobeginanyagnosticaspectafteradvicefrom Oncethemethod’spre-conditionhasbeensuccessfulvalidatedthis avalidstateaccordingtothemethod’spost-condition. Finally,af- shouldimmediatelyimplythepre-conditionfortheaspect’sbefore ter advice post-condition must directly imply the method’s post- adviceisalsotrue. Theaspectdeveloperknowsthemethod’spre- condition. Upon completion of an agnostic aspect’s after advice condition and has defined the aspect to be an obedient aspect, it isthereforetheaspectdeveloper’sresponsibilitytoacceptalllegal startingstatesofthemethodaslegalstartingstatesoftheaspect’s AssertionValidation BlameAssignment before advice. Failing to do so will signal an error blaming the mpre Caller aspectdeveloperforattemptingtouseanobedient aspectwithout mpre→αbpreef Aspect takingintoaccounttheoriginalmethod’spre-condition(Table3). αbef Advice post αbpeofst →mpre Aspect AssertionValidation BlameAssignment m Advice pre mpost Method mpre Caller mpost →αapfrteer Advice mpre→αbpreef Aspect αapfrteer Advice αbpeofst Advice αapfotsetr Advice mpost →αapfrteer Aspect αapfotsetr →mpost Aspect αapfrteer Advice mpost Aspect αapfotsetr Advice αapfotsetr →mpost Aspect Table2: Implicationsforagnosticaspectassertionsandblame assignment. Orderofexecutiongoesfromtop(first)tobottom Table 3: Assertions validated for obedient aspects (execution (last). flowsfromtoptobottom)alongwithblameassignments. 4 The aspect’s before advice post-condition is then checked. Fail- Inthiswayanextendedversionofthemethodcanbeprovidedto ing the before advice post-condition blames the advice code for clientprograms. Thiskindofextension, however, raisesanissue notfulfillingtheexpectedassertionuponitstermination. Thenext withclientsastowhichofthemethodspre-conditions areclients assertiontobecheckedisanimplicationrelationbetweentheorig- supposedtofollow? inal method’s post-condition and the after advice pre-condition. Blame is assigned to the aspect developer in the case of failure, Theansweriseitherone.Arebelliousaspectprovidesabehavioral for declaring an obedient aspect and not taking into account the methodextensionwithoutbreakingtheexistingmethod’scontracts, method’spost-conditionasavalidstartstatefortheaspect’safter i.e.,allowsforabroadersetofvalidstartstatesandanarrowerset advice. The after advice pre-condition is then checked, blaming ofvalidendstates.Thisisreflectedinthewayimplicationbetween thecompositionrules(pointcuts)inthecaseofanerror. Theafter assertions are being validated, after checking for the validity of advicepost-conditionvalidationfollowswhichblamestheadvice eachassertion,extraimplicationsbetweenpre-andpost-conditions codeincaseofanerror. Finallyanimplicationbetweentheafter arefurthervalidated. advice post-condition and the original method’s post-condition is validated. Thischeckmakessurethatthestateinwhichtheafter 3.3.2 BlameAssignment adviceterminates(andthusthewholecalltothemethod)doesso Blameassignment isdescribed in Table4. Theextraimplication invalidstateaccordingtothemethod’soriginalpost-condition. mpre → αbpreef makessurethattheextensionmadethroughtheas- pect definition maintains the previously valid start states for the Thedifferencebetweenagnosticandobedientaspectsissubtle. In method. Incasethatitdoesnotthentheblamelieswiththeaspect bothcases,ifthemethodpre-conditionisvalid,wecaninvokethe developerforprovidinganextensionthatbreaksexistingclientsof methodwithitsadvice, andtheresultsatisfiesthepost-condition. However,inthecaseoftheobedientaspectitispossiblethatabe- themethod. Theimplicationαbpeofst → mpre verifiesthatafterthe terminationofbeforeadviceandbeforetheexecutionflowstothe foreaspectwillinvalidatetheprecondition,themethodisexecuted method’simplementation,theprogramstatesatisfiesthemethod’s onastatethatdoesnotsatisfytheprecondition,andanafteradvice pre-condition.Ifbeforetheadvicepost-conditionimpliesthemethod’s fixes the postcondition (if necessary). Withagnostic aspects, the pre-conditionthenthemethodisnotbeingwronglyusedbytheas- methodcodeexecutesonlyinthecontextitwasmeantfor. pect. Theimplicationmpost → αapfrteer verifiesthatuponcomple- tionofthemethodbodyexecutionflowsintotheaspect’safterad- 3.3 Rebellious Aspects viceinacorrectstartstatefortheafteradvice.Itisthereforethere- Rebelliousaspectsareaspectsusedonlytoprovidebehavioralex- sponsibilityoftheaspectdevelopertomakesurethatallvalidstates tensionstoexistingmethods.Rebelliousaspectschangethebehav- reacheduponreturnofthemethodarealsovalidstartstatesforthe ior of existing methods. After the aspect is applied to a method, aspect’safteradvice.Finally,theimplicationαapfotsetr →mpostveri- fromtheperspectiveofacallerofthemethod,themethodwiththe fiesthatallthevalidstatesatafteradviceterminationarealsovalid advicehasdifferentassertionsthantheoriginalmethodhad. How- accordingtotheoriginalmethod’spost-condition. Thislastcheck ever,assertionsdonotchangefromthemethod’sperspective. verifiesthatthesetofvalidendstatesisthesameas,orasubsetof, theoriginalmethod’ssetofendstates. Asthecategorynameimplies,theseareaspectsthataredetermined toalterthebehaviorofamethodtotheextendwheretheexisting AssertionValidation BlameAssignment prerbe-elalinoduspoasstp-eccotnsdciatinonaslteorfathmeemtheothdo’sdparree-aafnfdecpteods.t-cNoonndeittihoenlessisn, mpre→αbpreef Aspect αbef Caller acontrolledmanner: pre αbef Advice post αbpeofst →mpre Aspect • For all valid start states of the method’s pre-condition, the mpre Advice newpre-condition(aspect’sbeforepre-condition)hastoalso mpost Method bevalid. mpost →αapfrteer Aspect αafter Advice pre • Forallvalidstatesaccordingtothenewpost-condition(as- αafter Advice post pheacstt’osaafltseorbpeosvta-cliodn.dition)theoriginalmethod’spost-condition αapfotsetr →mpost Aspect Table4:Implicationsforrebelliousaspectassertionsandblame assignment. Orderofexecutiongoesfromtop(first)tobottom Theaboveimplicationsbetweentheextendpre-condition(andorig- (last). inal method pre-condition) and extended post-condition (and the originalmethod’spost-condition)ensureproperbehavioralsubtype betweentheoriginalmethodandtheextensiontothemethod. 3.4 ApplicationandObliviousness ADbCforAOPsystemisabletoprovidefortheruntimevalida- 3.3.1 ExecutionOrder tionofassertionsonbothaspectsandobjectsallowingforthede- Arebelliousaspect isguaranteed anexecution sequence imposed tectionoferrorsduetoerroneous aspect adviceimplementations, erroneousaspectcompositionandaspectcategoryviolationsallow- bytheaspectthatallowsitsadvicetoexecuteevenbeforethemethod’s ingforfastererrordetectionandresolution. pre-condition. This enables the redefinition of the method’s pre- condition. Inordertoallowforthemethodsbehavioralextension The categorization into agnostic, obedient, and rebellious covers theexecutionorderenforcedbythelanguageis(fromlefttoright): all behaviors that aspects can introduce to a system. Along with αbef ;α;αbef ;m ;m;m ;αafter ;α;αafter theincorporationof pre-andpost-conditions foradvice, DbC for pre post pre post pre post 5 AOP can resolve the execution order question by, e.g., introduc- IntheremainingpartofthissectionwefurtherexplainCONAand ingthreenewkeywordstotheAspectJlanguagethatprogrammers the language extensions to Java and AspectJ as well as CONA’s can use to declare the categorizations of aspect implementations. mechanisms for contract enforcement. Firstan overview of DbC DbCsupport forAspectJwouldthenusethisclassificationtoen- forJavaispresentedfollowedbyamoredetailedanalysisofhow force the appropriate execution sequence according to each cate- CONAextendsDbCforOOPtoachieveDbCforAOP. gory. AspectJcouldalsoextendDbCtoaspectsbyallowingpre- and post-condition validation for advice and their implication on 4.1 AnAOPSolution toDbC forOOP pre- and post-conditions on their attached methods. Such an im- plementationofDbCforAOPdoesnotimposeanyrestrictionson TheAOPimplementationfortheprovisionofDbCforOOPmaps thebasecode,allowingthesamelevelofobliviousness[8]asinthe each Java type toa contract aspect that isresponsible for theen- currentimplementationsofAspectJ. forcementofallcontractsdefinedinthattype.Pre-andpost-conditions andinvariantexpressionsaregeneratedasaspectmethods. Point- 4. A CASE STUDY IN ENFORCING CON- cutsaregeneratedtocaptureexecutionsofatype’smethods.Point- cutsarefurtherusedtodistinguishwhichtype’smethodiscalled TRACTSUSINGASPECTSWITHCONA and which type’s implementation of this method is actually exe- Sofarwetacitlyignored thequestion of how theenforcement of cuted.Inthiswaythecorrecttypeisblamedinthecaseofacontract assertionsonmethods(andonadvice)isimplemented. Enforcing violation. Extramethodsaregeneratedwhichrecursivelytraverse runtimecontractcheckinginaprogramisaclassicalcross-cutting contractsofthecurrenttype’ssupertypesverifyingthecorrectness concernbyitsverynatureofmonitoringcallsmadebetweensoft- ofthetypehierarchy. wareentities[19,4].Attheheartofanyruntimecontractchecking tool lies the ability to observe and intervene between calls made Listing 2 shows an example of a contract aspect implementing a fromonesoftwareunittoanother. Thekindsofchecksthatneed contract in AspectJ. The code has been generated by CONA [27] to becarried out between callsdiffer depending on the paradigm anditillustratesthataspectsimplementingcontractscanfollowa (e.g., functional [10]vs. OOetc.). TheabilityofAOPtechnolo- pattern(template): pointcutdefinitionscapturecallstothemethod giestonon-invasivelyextendasystem,alongwiththeabilitytoen- (lines5–7),beforeadvicechecksmethodpre-conditions(lines8– capsulateandcomposecross-cuttingconcerns,makeAOPanideal 18), and after advice checks method’s post-conditions (lines 19– implementationtoolforDbC. 29).Invariantassertionsarecheckedbothbeforeandafteracallto theobject’spublicmethods. Auxiliarymethodsaregenerated in- CONA[27]isaDbCtoolforbothOOPandAOP.ItextendsJava’s sideaspectstodealwithhierarchychecking(lines36–51)[9].The andAspectJ’ssyntaxwithcontractsandenforcestheirruntimeval- recipeforCONA’saspectgenerationisexplainedelsewhere[28]. idation. CONAworksbygeneratingAspectJaspectstoenforcethe runtimecontractchecking. CONAgeneratesaspectdefinitionsonly BlameassignmentforOOP[9]issummarizedinTable5. Thelast for the validation of contracts on Java classes; it generates class two rows display the type hierarchy check performed in order to definitionsforthevalidationofcontractsonAspectJaspects. verify proper behavioral subtyping. Due to the lack of aspectual polymorphism[5,6]inAspectJ,thetraversalofcontractsinCONA InaCONAapplicationtherearealwaystwo“kinds”ofaspects deploysAspectJ’sreflectivefeaturesinordertoacquireaspectin- stancesatruntime. 1. User-Aspectstheseareaspectdefinitionsprovidedbydevel- TheAOPimplementationofDbCforOOPworkswellaslongas opersthataffecttheunderlyingJavaprogram. thegeneratedaspectsaretheonlyaspectsinthesystem. 2. Contract-Aspects these are generated by CONA and are re- sponsiblefortheenforcementofcontractsforobjects(DbC forOOP). 4.2 AnOOPSolution toDbC forAOP A DbC for AOP solution has to be able to enforce the execution sequencerequiredbyeachaspectcategoryaswellasmanagepre- andtwo“kinds”ofobjects andpost-conditionsfoundinuseraspectdefinitions. 1. User-ObjectsthesearealltheinstancesofuserdefinedJava Figure2usesaflowchartdiagramsuperimposedonaninteraction classes. diagram showing when obedient (top) and a rebellious (bottom) aspects intervene during m’s execution, and what is the order of 2. Contract-Objects these are all the instances of the CONA generatedJavaclassesusedfortheruntimevalidationofcon- tractsdefinedinsideuseraspects. ContractValue BlameAssignment ¬mpre Caller ∀τ,τ′(τ′≺:τ ∧τ::m∧τ′::m)→ Contracts on objects are implemented by contract aspects; con- tractsonaspectsareimplementedbycontractobjects. Thedesired ¬(τ::mpre →τ′::mpre) τ′ DbC functionality isguaranteed provided that the generated con- ¬mpost Callee tract aspects are the only aspects in the system. However, in the ∀τ,τ′(τ′≺:τ ∧τ::m∧τ′::m)→ presence of user aspects, and in particular, the interplay between ¬(τ′::mpost →τ::mpost) τ′ a contract aspect and user aspects, enforcing assertions correctly isnon-trivial. CONAisthereforeaninterestingtestbedforexpos- Table5: BlameassignmentrulesforOOP.τ′ ≺:τ definesthat ingtheissuesofexecutionorderandanaturalclientforouraspect τ′isadirectsubtypeofτ.τ::mpredenotesthemethodmwith classification. pre-conditionspreisdefinedintypeτ. 6 Figure2:Aflowchartdiagramsuperimposedonasequencediagramforamethodcalltomshowingtheorderofcontractevaluation forobedientaspects(top)andrebelliousaspects(bottom). m referstom’spre-conditionsassertionandαbeforeandαbeforetothe pre pre post aspect’spre-andpost-conditionassertionsrespectively. contract evaluation for these two aspect categories.3 Aspect cat- relatetothestateoftheaspect,andalsotothestateofthereceiver egorydefinitionsdenoteaspecificorder ofcontract evaluation as andthecallerofmethodinvocations.Allinformationconcerninga wellasimplicationsbetweenassertionsincontractaspectsandcon- joinpoint(e.g. target,args,source,etc.) canbereferredto tract objects. All diamond shaped decisions points aregenerated frominsideanaspect’spre-andpost-conditionsdefinitions. by CONA. DecisionspointsdenotedasdiamondsinFigure2and labeledwithanαpatternarecapturedasJavaclasses(contractob- Theprogrammermustspecifytheaspect’scategoryandtheaccept- jects). Diamondshapeddecisionpointslabeledwithanmpattern able states in which advice may start/finish. Failing to meet the arecapturedasAspectJaspects(contractaspects). pre-condition of a block of advice implies that the attachment of thespecificaspecttothebaseprogramP isnotcorrect(Listing4 To support pre- and post-conditions for before and after advice line18)andtheaspectgetsblamed.Similarly,ifthepost-condition weassumetheAspectJlanguagewasextendedwiththekeywords ofapieceofadvicefails,thisimpliesthatthecodeinsidethead- agnostic,obedient(e.g.,Listing3,line1),andrebellious, vicedidnotmeetuptoitsobligations(Listing4,line15)andthe and,furthermore,thatadvicedefinitionscanbeannotatedwithpre- advicecodegetstheblame. and post-conditions that apply to the corresponding advice body (Listing3lines7–8). Pre- andpost-conditions arecomprised of Oncepre-andpost-conditionshavebeensatisfied,thewaybywhich sideeffectfreebooleanexpressions. pre-andpost-conditionsofadviceinterplaywithmethodpre-and post-conditions of methods that they advice are checked for cor- TheextensionofCONAforaddingcontractstoadvicetakesasin- rectnessbasedontheaspectsdefinedcategory. put aspect definitions with pre- and post-conditions. Through a preprocessingstage,newaspectsaregeneratedtoverifycontracts Inthecaseofanobedientaspect(i.e.,ShippingCost),beforethe on object instances and auxiliary class definitions to handle pre- execution of the after advice block the implication between the andpost-conditionsonuserdefinedadvice. method’s post-condition and the after advice pre-condition (List- ing 4, line 7) is checked by passing control to an auxiliary class First we present a sample program definition of advice with pre- (Listing 5). Failing to satisfy this implication throws an Obedi- and post-conditions along with the generated output. Listing 3 entViolation (Listing 4, line 21) exception pointing out the er- showstheobedientShippingCostaspectpresentedearlierforthe roneous implementation of the aspect’s before advice. The ad- online bookstore example writtenin CONA. Listing4 shows the vicepre-conditionandpost-conditionisthenchecked,blamingthe sameaspectasListing3afterbeingprocessedbyCONA.Theaux- aspect’scomposition andtheafteradviceimplementation respec- iliaryclassdefinitions(Listings5and6)enforcetheimplications tively(Listing4,lines18and15) betweencontractobjectsandcontractaspects. Pre-andpost-conditionsinsideadvicemustbesideeffectfreeJava 5. DISCUSSION AND RELATED WORK boolean expressions. These expressions can refer to values that WehaveextendedDbCforAOPtohandletheinteractionbetween pre-andpost-conditionsofmethodsandadvice.Ourgoalwaspri- 3Agnosticaspectsaresimilartoobedientaspectswithsomeaddi- marilytodemonstratethefeasibilityanovelapproachforsupport- tionalcontractchecksinterleavedduringexecution. ingDbCforAOPwithoutcompromisingobliviousness. Wehave 7 alsopresentedaprototypedtoolforenforcingDbCbygenerating aspects. ThisworkpavestheroadtoextendingDbCforAOPbut Listing3: Anexampleofusingpre-andpost-conditionsinthe alsoleavesforfutureworkafewissuesthatareneedtobeworked ShippingCostaspect outforacompletepracticalsupportofDbCforAOP. 1 obedientaspectShippingCost{ pointcutHDSales(ISBNisbn): 2 3 call(∗OnlineBookstore.sales(..))&&args(isbn); 4 after(ISBNisbn)returning(Bookitem): 5 6 HDSales(isbn){ Listing2: AnaspectdefinitiongeneratedbyCONAforenforc- 7 @pre{item.getBookType()=HD} ingcontractobligationsofGRBranch. 8 @post{item.getShippingCost()=Calc.ShippingCost(item. 123 priGpvoiRlienBdtrgcaeundtchsacsooplpdeec;(t):G!RwBitrhainnc(hGRCBonratrnaccht{Contract) 109 iitteemm..csIeaStlBScuhNliap)tp∗eiTn1og.t1Ca}loCsot(sitt(e)m;.getShippingCost()∗1.1); 4 &&!cflow(withincode(∗GRBranch Contract.∗(..))); 11 } 5 pointcutGRBranch sale(GRBranchtInst,ISBNisbn): 12 } 6 call(public∗GRBranch.sale(..))&&!call(public∗( GRBranch+&&!GRBranch).sale(..)) &&args(isbn)&&target(tInst)&&scope(); 7 before(GRBranchtInst,ISBNisbn): 8 9 GRBranch sale(tInst,isbn){ Listing4: SampleoutputforShippingCostaspectshowing 10 booleannext=PreCondHier sale(tInst,isbn); thewrappingofadvicetocheckpre-andpost-conditions booleanres=PreCond sale(tInst,isbn); 11 1 aspectContract ShippingCost{ 12 if(!res){ 2 pointcutHDSales(ISBNisbn): 13 //pre−conditionviolationexception 3 call(∗OnlineBookstore.sales(..))&&args(isbn); 14 } 4 15 if(!next){ 5 after(ISBNisbn)returning(Bookitem): 16 //pre−conditionhierarchyviolationexception 6 HDSales(isbn){ 17 } 7 booleanimplication1=(new 18 } Contract ShippingCost After PreCond()).HDSales( 19 after(GRBranchtInst,ISBNisbn)returning(Bookresult): thisJoinPoint,this,thisJoinPoint.getTarget(),isbn, 20 GRBranch sale(tInst,isbn){ item); 21 booleanres=PostCond sale(tInst,result,isbn); 8 if(implication1){ 22 if(!res){ 9 if(item.getBookRype()==HD){ 23 //post−conditionviolationexception 10 item.setShippingCost(item.getShippingCost()∗1.1); 24 } 11 item.calculateTotalCost(); 25 booleanpostHier=PostCondHier sale(tInst,result,res,isbn) 12 if(item.getShippingCost()==Calc.ShippingCost(item. ; ISBN)∗1.1){ 26 if(!postHier){ 13 (newContract ShippingCost After PostCond). 27 //post−conditionhierarchyviolationexception HDSales(this,thisJoinPoint.getTarget(),isbn, 28 } item); 29 } 14 }else{ 30 publicbooleanPreCond sale(GRBranchtInst,ISBNisbn){ 15 newError(this,”before”,jp); 31 return(isbn.notEqual(null)) 16 } 32 } 17 }else{ 33 publicbooleanPostCond sale(GRBranchtInst,Bookresult, 18 newCompositionError(jp.getTarget().getClass(). ISBNisbn){ getName(),this,thisJoinPoint); 34 return(result.ISBN.equals(isbn)||isbn.getTitle().equals( 19 } result.getTitle())) 20 }else{ 35 } 21 newObedientViolation(jp.getTarget().getClass(). 36 publicbooleanPreCondHier sale(GRBranchtinst,ISBNisbn){ getName(),this,thisJoinPoint); 37 booleanmyPre=PreCond sale(tInst,isbn); 22 } 38 booleanhierarchy= 23 } OnlineBookstore Contract.aspectOf().PreCondHier sale( 39 tInst,isbn); 40 if(!hierarchy||myPre) returnmyPre; 41 InvariantsandObjectState. DbCmakestheobligation–benefit else 42 returnfalse; contractbetweensoftwareconsumersandprovidersexplicit. Each 43 44 } instancemethoddefinesthevalidstatesinwhichitsexecutioncan 45 publicbooleanPostCondHier sale(GRBranchtInst,Bookresult start(precondition),andthestatesinwhichitmayterminate(post- ,booleanlast,ISBNisbn){ condition). A more general assertion (invariant), which ismain- 46 myPost=PostCond sale(tInst,result,isbn); tained before as well as after any externally observable state of 47 if(!last||myPost) an object, ensures that the object maintains an acceptable state returnOnlineBookstore Contract.aspectOf(). 48 throughout theprogram’sexecution. Objectandaspect invariants PostCondHier sale(tInst,result,myPost,isbn); else can be checked by public methods as part of the pre- and post- 49 returnfalse; conditions using the same execution order we have established. 50 51 } However, tohandleinvariants, DbCforAOPneedsnotonlycon- 52 } trol theinteraction between aspects and object behavior, but also between aspects and object state. It is also not enough to moni- 8 action [25] should be handled similar tohow overriding methods Listing5:Pre-conditionwrapperforaspectafteradvice handle a call to super. One way of interpreting the aspect anno- 1 importorg.aspectj.lang.∗; tationforaroundadviceistorequirethatanaroundadviceofthe formf();proceed()wouldbehavelikeabeforeadvicewould,and 2 3 classContract ShippingCost After PostCond{ anaroundadviceoftheformproceed();f()wouldbehavelikean 4 afteradvice. publicbooleanHDSales(JoinPointjp,Contract ShippingCost 5 uAspect,Objecttarget,ISBNisbn,Bookitem){ IntroductionsandPointcutDescriptors.Wehaveconcernedour- StringtargetType=target.getClass().getName(); 6 selveswiththepointcutandadvicemechanisminAspectJ.AspectJ //Holdsreferencestocontract(aspects) 7 AspectMethInvokeraInv=AspectMethInvoker.getInst(); alsosupport astaticOCmechanism (e.g., introductions). Thisis 8 yetanotherformforapossibleinteractionbetweenanaspectand 9 10 //callappropriatecontractsviareflection a class which we do not handle. Another subtle issue is the in- 11 booleanm post=aInv.invokePost(targetType,jp.getSignature teraction between aspects and pointcuts. In our support of DbC (),jp.getArgs(),item); forAOPwehavethusfarassumedthatpointcutshavenosideef- booleanres=(item.getShippingCost()==Calc.ShippingCost( 12 fects. This, however, isnot generally true, not even for AspectJ. item.ISBN)∗1.1); 13 if(!res||m post){ Onemightconsideraugmentingpointcutdescriptorswithpre-and returnres; post-conditionsoftheirown. 14 15 } 16 else{ AspectCompositionValidationTool. Klaerenetal.[13]present 17 newCompositionError(targetType,uAspect,jp); theAspectCompositionValidationToolforcheckingpre-andpost- returnfalse; 18 conditionsforaspect compositionsaccordingtoconfigurationsof 19 } the system’s components. The tool is developed using an older 20 } version of AspectJ (0.4beta7) which is drastically different than 21 } version1.0.6. Further more, asetof configuration rulesisadded through AspectJ’s introductions and composition is validated ac- cordingtotheserules. Correctnessisdefinedtobeavalidaspect configurationthatwillallowareceivertoperformitstaskasspec- Listing6:Post-conditionwrapperforaspectafteradvice ifiedbytheoverallsystemspecification. Unfortunately, checking 1 importorg.aspectj.lang.∗; that the behavior of attached aspects and the base system is well defined is not verified. As long as the composition of aspects is 2 3 classContract ShippingCost After PostCond{ withinthesetofvalidcompositions,thesystemiscorrect. Anas- 4 pectcanthereforebreakamethodspre-orpost-conditionaslong publicbooleanHDSales(JoinPointjp,Contract ShippingCost 5 astheconfigurationathandallowsit. Thereisnocleardistinction uAspect,Objecttarget,ISBNisbn,Bookitem){ betweenatype’sobligationsintheirsystem,sincethesamecallto StringtargetType=target.getClass().getName(); 6 //Holdsreferencestocontract(aspects) aninstanceofthesametypecanbehavedifferentlydependingon 7 AspectMethInvokeraInv=AspectMethInvoker.getInst(); itsaspectconfiguration. 8 9 10 //callappropriatecontractsviareflection JML.CliftonandLeavens[2]usebehavioralspecificationsforas- booleanm post=aInv.invokePost(targetType,jp.getSignature 11 pectsasameanstoassistinmodularreasoningforaspect-oriented (),jp.getArgs(),item); programs. Aspectsarecategorizedaseitherobserversthatdonot booleanres=(item.getShippingCost()==Calc.ShippingCost( 12 item.ISBN)∗1.1); alter the behavioral specification of their attached methods, or as 13 if(!res||m post){ assistantsthatcanalterbehavior. Theircategorizationwasaresult 14 returnres; afterinspectingavailableAspectJcodeandfromdiscussionswithin 15 } theaspectcommunity. 16 else{ newCompositionError(targetType,uAspect,jp); 17 AssertionsonaspectsaswellasobjectsareexpressedintheJava returnfalse; 18 Modeling Language(JML)[16]. TheAspectJsyntaxisextended 19 } withthreemainfeatures: 20 } 21 } 1. JML can be used inside aspect definitions, defining the as- pect’sbehavioralspecification tor only call and execution join points. Since advise can change 2. Keywordsobserverandassistantcanbeusedtoan- thestateofanobject, theinteractionbetweenadviceandobjects’ notateaspectdefinitionswiththeirexpectedintendinthesys- stateneedtocheckedtoenforceinvariants. Additionalchecksare tem. neededforcheckingtheinvariantofsuper-classesandouterclasses. Invariantsforaspectsareparticularlyusefulasaninductivehypoth- 3. Thestatementaccept(TypePatern)hastobeusedinside esis:Whateverisassumedshouldbeinductivelyprovable. modules, makingexplicitthemodulesintenttoallowassis- tancefromTypePatern. OtherKindsof Advice. Wehavefocused ontheinteractionbe- tween methods and before and after advice. An around advice replaces the method entirely and may or may not contain a pro- Thespecificationofamethodalongwithitsassistantiscreatedasa ceed() call in its body. Such a narrowing or replacement inter- graphbyfollowingthepossibleexecutionpaths,logicallyand-ing 9 assertionsandbindingparametervariablesandmodelvariablesto between contracts on aspects and contracts in classes. Based on values. thesedecisionsofexecutionorderandcontractimplications,blame assignmentcanbedefined. AlthoughourgoalsaredifferentthanthoseofCliftonandLeavens theproposals sharesome ideas. Our notionof aspect categoriza- We provide an analysis of the possible execution order between tioncomesfromananalysisofhow aspectscanaffectaprogram contractsandviewtheadditionofadviceasabehavioralextension execution andnotthrough ananalysisofexistingusageofaspect totheexistingprogram. Ouranalysisleadsustoacategorization oriented programming. In doing so we aim at providing a cate- ofaspectsintoagnostic, obedientandrebellious. Eachsuchcate- gorization that covers any possible usage of aspects rather than gorizationenforcesanexecutionorderbetweencontractsaswellas thecommon usageof aspects. Furthermore, our proposal brings thenecessaryimplicationsthatverifyatruntimethattheextended thesecategorizationsintotheprogramminglanguageandenforces (through aspects)systemremainsabehavioral subtype of theun- anexecutionorderdisallowingaspectbehavioroutsidethebounds extended original system. Error reporting and blame assignment ofitsdefinedcategory. Enforcinganexecutionsequencehelpsin isextended todeal withcontracted aspect oriented systems. Our definingthesemanticsofassertionvalidationalongwithblameas- ideashavebeenintegratedinCONA,anaspect-basedDbCtoolfor signment without having to resort to long and complicated path AOPwhichusesaspectstoimplementcontractsandtheirruntime specificationsbasedoncontrolflowpaths. Finally,inourproposal validation. CONAservesbothasalanguageextensiontoJavaand modules are not affected in any way and remain oblivious to the AspectJ,butalsoasacasestudyforourownwork. additionofaspects. ObliviousnessisdecreasedinCliftonetal.[2] withtheincorporationoftheacceptexpressioninthelanguage. ThroughthedevelopmentandusageofCONAwehopetoimprove theabilitytoreasoningabouttheinteractionsofaspectswithother Pipa. Pipa[31]definesaBehavioralInterfaceSpecificationLan- programentitiesincludingaspectsthemselves. Webelievethatthe guage (BISL) tailored for AspectJ along the ideas of Clifton et incorporationofpre-andpost-conditionsonbeforeandafter al.[2].PipastatementsextendtheJavaModelingLanguage(JML) adviceisastepforwardtowardsreasoningaboutaspectsandtheir toaccommodatepre-andpost-conditionsandinvariantsforadvice. behavior. SpecificationsinPipa,alongwithaspectdefinitions,aretranslated toJMLandJavacode,respectively. Pipadiffersfromtheproposal 7. REFERENCES ofCliftonandLeaves. Assertionsareallowedonaspectintroduc- [1] AOSD2003.Proceedingsofthe2ndInternational tions and the accept expression is not provided by Pipa. Fur- ConferenceonAspect-OrientedSoftwareDevelopment, ther more, theAspectJlanguage isnot extendedtoaccommodate Boston,Massachusetts,Mar.17-212003.ACMPress. for the definition of observer and assistant aspect defini- tions. Behavioral specifications inside aspects are translated into [2] C.CliftonandG.T.Leavens.Observersandassistants:A JML specifications following the specification generation of exe- proposalformodularaspect-orientedreasoning.Technical cutionpathsasdefinedin[2]. Pipadoesnotprovide,norenforce, Report02-04a,IowaStateUniversity,Departmentof aspectcategories.ByconcentratingonAspectJ’sintermediateJava ComputerScience,Apr.2002. representation of aspect programs, Pipa becomes part of the As- [3] A.Colyer.Aspectj.InFilmanetal.[7],pages123–143. pectJ compiler making extensions difficult andblame assignment morecomplex. [4] C.A.ConstantinidesandT.Skotiniotis.Reasoningaboutthe classificationofcrosscuttingconcernsinobject-oriented Classification system. Rinard et al. [25] present a classification systems.InSecondInternationalWorkshopon that is also derived from the interaction of advice and methods. Aspect-OrientedSoftwareDevelopment.GermanInformatics Their focus ison automated analysis, whileour work focuses on Society,February21-222002. enforcingcontractsbasedonannotations. Theinteractionbetween agnosticaspectsandmethodscanbeclassifiedasaugmentationin [5] E.ErnstandD.H.Lorenz.Aspectualpolymorphism. their classification. The obedient and rebellious aspects we have TechnicalReportNU-CCS-01-09,CollegeofComputer identifiedrefinetheircombination classofinteractions. Thenar- Science,NortheasternUniversity,Boston,MA02115,Sept. rowingandreplacementinteractionscanhelpinextendingourwork 2001. toalsohandlearoundadvicewithorwithoutproceed. Theiraddi- [6] E.ErnstandD.H.Lorenz.Aspectsandpolymorphismin tionalclassificationofscopesandfieldaccess,canalsohelpinex- AspectJ.InAOSD2003[1],pages150–157. tendingourDbCtooltohandleset-fieldandget-fieldadvice. Au- http://www.ccs.neu.edu/home/lorenz/papers/aosd2003polyspe tomated classification to help suggest or verify aspect categories annotationisadirectionforfuturework. [7] R.E.Filman,T.Elrad,S.Clarke,andM.Aks¸it,editors. Aspect-OrientedSoftwareDevelopment.Addison-Wesley, 6. CONCLUSION Boston,2005. The paper discusses the intricate issues related to DbC for AOP. [8] R.E.FilmanandD.P.Friedman.Aspect-oriented Thedynamicnatureofaspectsalongwiththebasesystem’soblivi- programmingisquantificationandobliviousness.InFilman ousnessrenderexistingDbCmethodologiesinadequatefordealing etal.[7],pages21–35. withaspect-orientedprograms.Thisinadequacyunavoidablyleads toerroneouserrorreportingandblameassignment. Anextension [9] R.B.FindlerandM.Felleisen.Contractsoundnessfor toDbCtoaddressaspect-orientedprogrammingrequiresmorethan object-orientedlanguages.InProceedingsofthe16thAnnual simpleassertionvalidationateachprogramexecutionpointwhere ConferenceonObject-OrientedProgrammingSystems, aspectadvicegetstoexecute. ADbCmechanismforAOPhasto Languages,andApplications,pages1–15,TampaBay, address both the execution order of contracts (on classes and as- Florida,Oct.14-182001.OOPSLA’01,ACMSIGPLAN pects) as well as the implications (if any) that must be validated Notices36(11)Nov.2001. 10

See more

The list of books you might like

Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.