All Downloads are FREE. Search and download functionalities are using the official Maven repository.

core_snowflakeapp.showcase.showcaseModel.pure Maven / Gradle / Ivy


import meta::external::function::activator::snowflakeApp::tests::*;
import meta::external::function::activator::snowflakeApp::tests::model::simple::*;
import meta::core::runtime::*;
import meta::relational::runtime::*;
import meta::external::store::relational::runtime::*;
import meta::relational::metamodel::*;


Class meta::external::function::activator::snowflakeApp::tests::model::simple::PersonX
{
    firstName : String[1];
    lastName : String[1];
    otherNames : String[*];
    extraInformation : String[0..1];
    manager : PersonX[0..1];
    gender: Gender[0..1];
    genderFromInt: Gender[0..1];
    age : Integer[0..1];
    nickName : String[0..1];    
    activeEmployment: Boolean[0..1];
    lastUpdated: DateTime[0..1];
    name(){$this.firstName+' '+$this.lastName}:String[1];

}

Enum meta::external::function::activator::snowflakeApp::tests::model::simple::Gender {
  M, F
}

function meta::external::function::activator::snowflakeApp::tests::testRuntime(db:Database[1]):Runtime[1]
{
    testRuntime(testDatabaseConnection($db,[]->cast(@String)));
}

function meta::external::function::activator::snowflakeApp::tests::testRuntimeWithTimeZone(db:Database[1]):Runtime[1]
{
    testRuntime(testDatabaseConnection($db, '+0530'));
}

function meta::external::function::activator::snowflakeApp::tests::testRelationalConnection():ConnectionStore[1]
{
  ^ConnectionStore(
    element = dbInc ,connection=
  ^RelationalDatabaseConnection(
    type = DatabaseType.Snowflake,
    datasourceSpecification = ^meta::pure::alloy::connections::alloy::specification::LocalH2DatasourceSpecification(testDataSetupCsv = ''),
    authenticationStrategy = ^meta::pure::alloy::connections::alloy::authentication::TestDatabaseAuthenticationStrategy()
  ))
}

function <> meta::external::function::activator::snowflakeApp::tests::testRuntime(testConnection:ConnectionStore[1]):Runtime[1]
{
   ^Runtime(connectionStores = $testConnection)
}

function <> meta::external::function::activator::snowflakeApp::tests::testDatabaseConnection(db:Database[1], timeZone:String[0..1]):ConnectionStore[1]
{
    ^ConnectionStore(
        element = $db,
        connection=
    ^meta::external::store::relational::runtime::TestDatabaseConnection(
        type = DatabaseType.Snowflake,
        timeZone = if($timeZone->isEmpty(), |'GMT', |$timeZone)
    ));
}


###Mapping

import meta::external::function::activator::snowflakeApp::tests::model::simple::*;
import meta::external::function::activator::snowflakeApp::tests::*;


Mapping meta::external::function::activator::snowflakeApp::tests::simpleRelationalMapping
(

    PersonX : Relational
            {
                scope([dbInc])
                (
                    firstName : personTable.FIRSTNAME,
                    age : personTable.AGE,
                    gender:  EnumerationMapping genderEnum: personTable.GENDER,
                    genderFromInt:  EnumerationMapping genderEnum2: personTable.GENDER2
                ),
                scope([dbInc]default.personTable)
                (
                    lastName : LASTNAME,
                    lastUpdated: LAST_UPDATED
                ),
                manager : [dbInc]@Person_Manager
            }

    Gender: EnumerationMapping genderEnum
    {
          M:  'male',
          F: ['female', 'Female']
    }

    Gender: EnumerationMapping genderEnum2
    {
          M:  1,
          F: 2
    }
)



Mapping meta::external::function::activator::snowflakeApp::tests::simpleRelationalMapping2
(

    PersonX : Relational
            {
                scope([dbInc])
                (
                    firstName : concat(personTable.FIRSTNAME,'__X'),
                    age : personTable.AGE
                ),
                scope([dbInc]default.personTable)
                (
                    lastName : concat(LASTNAME,'__X')
                ),
                manager : [dbInc]@Person_Manager
            }


)


###Relational
Database meta::external::function::activator::snowflakeApp::tests::dbInc
(
    Table personTable (ID INT PRIMARY KEY, FIRSTNAME VARCHAR(200), LASTNAME VARCHAR(200), AGE INT, ADDRESSID INT, FIRMID INT, MANAGERID INT, GENDER VARCHAR(200), GENDER2 INT,LAST_UPDATED TIMESTAMP)
    Table validPersonTable (ID INT PRIMARY KEY, FIRSTNAME VARCHAR(200), LASTNAME VARCHAR(200), AGE INT, ADDRESSID INT, FIRMID INT, MANAGERID INT)
    Table PersonTableExtension (ID INT PRIMARY KEY, FIRSTNAME VARCHAR(200), LASTNAME VARCHAR(200), AGE INT, ADDRESSID INT, FIRMID INT, MANAGERID INT, birthDate DATE)
    Table differentPersonTable (ID INT PRIMARY KEY, FIRSTNAME VARCHAR(200), LASTNAME VARCHAR(200), AGE INT, ADDRESSID INT, FIRMID INT, MANAGERID INT)

    Table firmTable(ID INT PRIMARY KEY, LEGALNAME VARCHAR(200), ADDRESSID INT, CEOID INT)
    Table firmExtensionTable(firmId INT PRIMARY KEY, legalName VARCHAR(200), establishedDate DATE)
    Table otherFirmTable(ID INT PRIMARY KEY, LEGALNAME VARCHAR(200), ADDRESSID INT)

    Table addressTable(ID INT PRIMARY KEY, TYPE INT, NAME VARCHAR(200), STREET VARCHAR(100), COMMENTS VARCHAR(100))
    Table locationTable(ID INT PRIMARY KEY, PERSONID INT, PLACE VARCHAR(200),date DATE)
    Table placeOfInterestTable(ID INT PRIMARY KEY,locationID INT PRIMARY KEY, NAME VARCHAR(200))

    View PersonFirmView
    (
        PERSON_ID: personTable.ID PRIMARY KEY,
        lastName:  personTable.LASTNAME,
        firm_name :  @Firm_Person | firmTable.LEGALNAME
    )

    View FirstNameAddress
    (
       ~distinct
       firstName: personTable.FIRSTNAME  PRIMARY KEY,
       address :  @Address_Person | addressTable.NAME PRIMARY KEY
    )

    View personViewWithGroupBy
    (
       ~groupBy(personTable.ID)
       id: personTable.ID PRIMARY KEY,
       maxage: max(personTable.AGE)
    )

    View PersonViewWithDistinct
    (
      ~distinct
      id: @PersonWithPersonView| personTable.ID PRIMARY KEY,
      firstName: @PersonWithPersonView| personTable.FIRSTNAME,
      lastName: @PersonWithPersonView|personTable.LASTNAME,
      firmId: @PersonWithPersonView|personTable.FIRMID
    )

    Schema productSchema
    (
       Table productTable(ID INT PRIMARY KEY, NAME VARCHAR(200))
    )

    Filter FirmXFilter(firmTable.LEGALNAME = 'Firm X')
    Filter FirmBFilter(firmTable.LEGALNAME = 'Firm B')

    Join personViewWithFirmTable(firmTable.ID = PersonViewWithDistinct.firmId)
    Join PersonWithPersonView(personTable.ID = personViewWithGroupBy.id and personTable.AGE = personViewWithGroupBy.maxage)
    Join Address_Firm(addressTable.ID = firmTable.ADDRESSID)
    Join Address_Person(addressTable.ID = personTable.ADDRESSID)
    Join Firm_Ceo(firmTable.CEOID = personTable.ID)
    Join Firm_Person(firmTable.ID = personTable.FIRMID)
    Join Firm_Person1(firmTable.ID = personTable.FIRMID and firmTable.LEGALNAME = 'Firm X')
    Join Firm_Person2(firmTable.ID = personTable.FIRMID and personTable.FIRSTNAME = 'Peter')
    Join FirmExtension_PersonExtension(firmExtensionTable.firmId = PersonTableExtension.FIRMID)
    Join Person_Location(personTable.ID = locationTable.PERSONID)
    Join Person_Manager(personTable.MANAGERID = {target}.ID)
    Join location_PlaceOfInterest(locationTable.ID  = placeOfInterestTable.locationID)
    Join Person_OtherFirm(personTable.FIRMID = otherFirmTable.ID)

)




© 2015 - 2025 Weber Informatics LLC | Privacy Policy