diff --git a/.github/workflows/subgraph.yml b/.github/workflows/subgraph.yml new file mode 100644 index 00000000..3ea20e8c --- /dev/null +++ b/.github/workflows/subgraph.yml @@ -0,0 +1,64 @@ +name: Subgraph + +on: + pull_request: + branches: + - main + - dev + - release/* + push: + branches: + - main + - dev + - release/* + +jobs: + test: + runs-on: ubuntu-latest + + defaults: + run: + working-directory: subgraph + + steps: + - name: Check out the repo + uses: actions/checkout@v3 + + - name: Install Pnpm + uses: pnpm/action-setup@v2 + with: + version: 8 + run_install: false + + - name: Install Node.js + uses: actions/setup-node@v3 + with: + node-version: 18 + cache: pnpm + + - name: Get pnpm store directory + shell: bash + run: | + echo "STORE_PATH=$(pnpm store path --silent)" >> $GITHUB_ENV + + - uses: actions/cache@v3 + name: Setup pnpm cache + with: + path: ${{ env.STORE_PATH }} + key: ${{ runner.os }}-pnpm-store-${{ hashFiles('**/pnpm-lock.yaml') }} + restore-keys: | + ${{ runner.os }}-pnpm-store- + + - name: Install dependencies + run: pnpm install --frozen-lockfile + + - name: Build the subgraph + run: pnpm run build:goerli + + - name: Run the unit tests + run: pnpm run test + + - name: Add test summary + run: | + echo "## Unit tests result" >> $GITHUB_STEP_SUMMARY + echo "✅ Passed" >> $GITHUB_STEP_SUMMARY diff --git a/.gitignore b/.gitignore index 157884c0..89c5cbdd 100644 --- a/.gitignore +++ b/.gitignore @@ -25,6 +25,9 @@ typechain-types build generated subgraph.yaml +.bin +.latest.json +.docker # Misc .DS_Store diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 79428e9c..43d5701a 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -1,9 +1,5 @@ lockfileVersion: '6.0' -settings: - autoInstallPeers: true - excludeLinksFromLockfile: false - overrides: flat@<5.0.1: '>=5.0.1' ejs@<3.1.7: '>=3.1.7' @@ -140,11 +136,17 @@ importers: subgraph: devDependencies: '@graphprotocol/graph-cli': - specifier: 0.58.0 - version: 0.58.0(@types/node@20.8.0)(node-fetch@3.3.2)(typescript@5.2.2) + specifier: 0.60.0 + version: 0.60.0(@types/node@20.8.0)(node-fetch@3.3.2)(typescript@5.2.2) '@graphprotocol/graph-ts': specifier: 0.31.0 version: 0.31.0 + assemblyscript: + specifier: 0.19.10 + version: 0.19.10 + matchstick-as: + specifier: 0.6.0 + version: 0.6.0 packages: @@ -2256,8 +2258,8 @@ packages: tslib: 2.6.2 dev: false - /@graphprotocol/graph-cli@0.58.0(@types/node@20.8.0)(node-fetch@3.3.2)(typescript@5.2.2): - resolution: {integrity: sha512-EbdL5LZFmIMAuItQXv7LXgd7cqYQ3BdIJR2jxNr+LRL0juBAxmEz6zVvYnIUmgXoa5SB5rxE9ZT6pfe+fhbD6Q==} + /@graphprotocol/graph-cli@0.60.0(@types/node@20.8.0)(node-fetch@3.3.2)(typescript@5.2.2): + resolution: {integrity: sha512-8tGaQJ0EzAPtkDXCAijFGoVdJXM+pKFlGxjiU31TdG5bS4cIUoSB6yWojVsFFod0yETAwf+giel/0/8sudYsDw==} engines: {node: '>=14'} hasBin: true dependencies: @@ -5211,7 +5213,7 @@ packages: /@types/cli-progress@3.11.2: resolution: {integrity: sha512-Yt/8rEJalfa9ve2SbfQnwFHrc9QF52JIZYHW3FDaTMpkCvnns26ueKiPHDxyJ0CS//IqjMINTx7R5Xa7k7uFHQ==} dependencies: - '@types/node': 20.5.7 + '@types/node': 20.8.0 dev: true /@types/concat-stream@1.6.1: @@ -5223,7 +5225,7 @@ packages: /@types/connect@3.4.36: resolution: {integrity: sha512-P63Zd/JUGq+PdrM1lv0Wv5SBYeA2+CORvbrXbngriYY0jzLUWfQMQQxOhjONEz/wlHOAxOdY7CY65rgQdTjq2w==} dependencies: - '@types/node': 20.5.7 + '@types/node': 20.8.0 dev: true /@types/form-data@0.0.33: @@ -5352,7 +5354,7 @@ packages: /@types/ws@7.4.7: resolution: {integrity: sha512-JQbbmxZTZehdc2iszGKs5oC3NFnjeay7mtAWrdt7qNtAVK0g19muApzAy4bm9byz79xa2ZnO/BOBC2R8RC5Lww==} dependencies: - '@types/node': 20.5.7 + '@types/node': 20.8.0 dev: true /@types/ws@8.5.6: @@ -8426,7 +8428,7 @@ packages: dependencies: inflight: 1.0.6 inherits: 2.0.4 - minimatch: 9.0.3 + minimatch: 3.1.2 once: 1.4.0 path-is-absolute: 1.0.1 dev: true @@ -8437,7 +8439,7 @@ packages: fs.realpath: 1.0.0 inflight: 1.0.6 inherits: 2.0.4 - minimatch: 9.0.3 + minimatch: 3.1.2 once: 1.4.0 path-is-absolute: 1.0.1 dev: true @@ -10622,6 +10624,12 @@ packages: resolution: {integrity: sha512-1RUZVgQlpJSPWYbFSpmudq5nHY1doEIv89gBtF0s4gW1GF2XorxcA/70M5vq7rLv0a6mhOUccRsqkwhwLCIQ2Q==} dev: true + /matchstick-as@0.6.0: + resolution: {integrity: sha512-E36fWsC1AbCkBFt05VsDDRoFvGSdcZg6oZJrtIe/YDBbuFh8SKbR5FcoqDhNWqSN+F7bN/iS2u8Md0SM+4pUpw==} + dependencies: + wabt: 1.0.24 + dev: true + /mcl-wasm@0.7.9: resolution: {integrity: sha512-iJIUcQWA88IJB/5L15GnJVnSQJmf/YaxxV6zRavv83HILHaJQb6y0iFyDMdDO0gN8X37tdxmAOrH/P8B6RB8sQ==} engines: {node: '>=8.9.0'} @@ -11062,6 +11070,7 @@ packages: engines: {node: '>=16 || 14 >=14.17'} dependencies: brace-expansion: 2.0.1 + dev: false /minimist@1.2.8: resolution: {integrity: sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA==} @@ -11265,7 +11274,7 @@ packages: resolution: {integrity: sha512-tmPX422rYgofd4epzrNoOXiE8XFZYOcCq1vD7MAXCDO+O+zndlA2ztdKKMa+EeuBG5tHETpr4ml4RGgpqDCCAg==} engines: {node: '>= 0.10.5'} dependencies: - minimatch: 9.0.3 + minimatch: 3.1.2 dev: false /node-domexception@1.0.0: @@ -13139,7 +13148,7 @@ packages: dependencies: '@istanbuljs/schema': 0.1.3 glob: 7.2.3 - minimatch: 9.0.3 + minimatch: 3.1.2 dev: true /text-table@0.2.0: @@ -13758,6 +13767,11 @@ packages: resolution: {integrity: sha512-gQpnTgkubC6hQgdIcRdYGDSDc+SaujOdyesZQMv6JlfQee/9Mp0Qhnys6WxDWvQnL5WZdT7o2Ul187aSt0Rq+w==} dev: false + /wabt@1.0.24: + resolution: {integrity: sha512-8l7sIOd3i5GWfTWciPL0+ff/FK/deVK2Q6FN+MPz4vfUcD78i2M/49XJTwF6aml91uIiuXJEsLKWMB2cw/mtKg==} + hasBin: true + dev: true + /walker@1.0.8: resolution: {integrity: sha512-ts/8E8l5b7kY0vlWLewOkDXMmPdLcVV4GmOQLyxuSswIJsweeFZtAsMF7k1Nszz+TYBQrlYRmzOnr398y1JemQ==} dependencies: @@ -14149,3 +14163,7 @@ packages: /zod@3.22.4: resolution: {integrity: sha512-iC+8Io04lddc+mVqQ9AZ7OQ2MrUKGN+oIQyq1vemgt46jwCwLfhq7/pwnBnNXXXZb8VTVLKwp9EDkx+ryxIWmg==} dev: false + +settings: + autoInstallPeers: true + excludeLinksFromLockfile: false diff --git a/subgraph/package.json b/subgraph/package.json index 0b35af66..8e3d02ec 100644 --- a/subgraph/package.json +++ b/subgraph/package.json @@ -24,10 +24,13 @@ "deploy": "source .env && cp subgraph.mainnet.yaml subgraph.yaml && pnpm run build && graph deploy --network linea-mainnet --node $DEPLOY_ENDPOINT_MAINNET --headers \"{\\\"Authorization\\\": \\\"Basic $IPFS_IDENTIFIERS\\\"}\" --ipfs $IPFS_ENDPOINT --version-label v0.0.1 Consensys/linea-attestation-registry", "deploy:goerli": "source .env && cp subgraph.goerli.yaml subgraph.yaml && pnpm run build:goerli && graph deploy --network linea-goerli --node $DEPLOY_ENDPOINT_GOERLI --headers \"{\\\"Authorization\\\": \\\"Basic $IPFS_IDENTIFIERS\\\"}\" --ipfs $IPFS_ENDPOINT --version-label v0.0.5 Consensys/linea-attestation-registry", "remove": "source .env && graph remove --node $DEPLOY_ENDPOINT_MAINNET Consensys/linea-attestation-registry", - "remove:goerli": "source .env && graph remove --node $DEPLOY_ENDPOINT_GOERLI Consensys/linea-attestation-registry" + "remove:goerli": "source .env && graph remove --node $DEPLOY_ENDPOINT_GOERLI Consensys/linea-attestation-registry", + "test": "graph test" }, "devDependencies": { - "@graphprotocol/graph-cli": "0.58.0", - "@graphprotocol/graph-ts": "0.31.0" + "@graphprotocol/graph-cli": "0.60.0", + "@graphprotocol/graph-ts": "0.31.0", + "matchstick-as": "0.6.0", + "assemblyscript": "0.19.10" } } diff --git a/subgraph/src/module-registry.ts b/subgraph/src/module-registry.ts index 2b87823b..612dd9f6 100644 --- a/subgraph/src/module-registry.ts +++ b/subgraph/src/module-registry.ts @@ -1,16 +1,14 @@ -import { ModuleRegistered as ModuleRegisteredEvent, ModuleRegistry } from "../generated/ModuleRegistry/ModuleRegistry"; +import { ModuleRegistered as ModuleRegisteredEvent } from "../generated/ModuleRegistry/ModuleRegistry"; import { Counter, Module } from "../generated/schema"; export function handleModuleRegistered(event: ModuleRegisteredEvent): void { - const contract = ModuleRegistry.bind(event.address); - const moduleData = contract.modules(event.params.moduleAddress); - const module = new Module(event.params.moduleAddress.toHex()); + const module = new Module(event.params.moduleAddress.toHexString()); incrementModulesCount(); - module.moduleAddress = moduleData.getModuleAddress(); - module.name = moduleData.getName(); - module.description = moduleData.getDescription(); + module.moduleAddress = event.params.moduleAddress; + module.name = event.params.name; + module.description = event.params.description; module.save(); } diff --git a/subgraph/src/portal-registry.ts b/subgraph/src/portal-registry.ts index f8b3ae22..811700c3 100644 --- a/subgraph/src/portal-registry.ts +++ b/subgraph/src/portal-registry.ts @@ -5,15 +5,15 @@ import { Counter, Portal } from "../generated/schema"; export function handlePortalRegistered(event: PortalRegisteredEvent): void { const contract = PortalRegistry.bind(event.address); const portalData = contract.getPortalByAddress(event.params.portalAddress); - const portal = new Portal(event.params.portalAddress.toHex()); + const portal = new Portal(event.params.portalAddress.toHexString()); incrementPortalsCount(); + portal.name = event.params.name; + portal.description = event.params.description; portal.ownerAddress = portalData.ownerAddress; portal.modules = changetype(portalData.modules); portal.isRevocable = portalData.isRevocable; - portal.name = portalData.name; - portal.description = portalData.description; portal.ownerName = portalData.ownerName; portal.save(); diff --git a/subgraph/src/schema-registry.ts b/subgraph/src/schema-registry.ts index 816e5e6a..cc2069bd 100644 --- a/subgraph/src/schema-registry.ts +++ b/subgraph/src/schema-registry.ts @@ -1,17 +1,15 @@ -import { SchemaCreated as SchemaCreatedEvent, SchemaRegistry } from "../generated/SchemaRegistry/SchemaRegistry"; +import { SchemaCreated as SchemaCreatedEvent } from "../generated/SchemaRegistry/SchemaRegistry"; import { Counter, Schema } from "../generated/schema"; export function handleSchemaCreated(event: SchemaCreatedEvent): void { - const contract = SchemaRegistry.bind(event.address); - const schemaData = contract.getSchema(event.params.id); - const schema = new Schema(event.params.id.toHex()); + const schema = new Schema(event.params.id.toHexString()); incrementSchemasCount(); - schema.name = schemaData.name; - schema.description = schemaData.description; - schema.context = schemaData.context; - schema.schema = schemaData.schema; + schema.name = event.params.name; + schema.description = event.params.description; + schema.context = event.params.context; + schema.schema = event.params.schemaString; schema.save(); } diff --git a/subgraph/tests/module-registry.test.ts b/subgraph/tests/module-registry.test.ts new file mode 100644 index 00000000..3ca7796a --- /dev/null +++ b/subgraph/tests/module-registry.test.ts @@ -0,0 +1,72 @@ +import { afterEach, assert, clearStore, describe, test } from "matchstick-as"; +import { + ModuleRegistered as ModuleRegisteredEvent, + ModuleRegistered, +} from "../generated/ModuleRegistry/ModuleRegistry"; +import { Address, ethereum } from "@graphprotocol/graph-ts"; +import { newTypedMockEvent } from "matchstick-as/assembly/defaults"; +import { handleModuleRegistered } from "../src/module-registry"; + +describe("handleModuleRegistered()", () => { + const moduleAddress = "f75be6f9418710fd516fa82afb3aad07e11a0f1b"; + const moduleName = "module name"; + const moduleDescription = "module description"; + + afterEach(() => { + clearStore(); + }); + + test("Should create a new Module entity", () => { + assert.entityCount("Module", 0); + + const moduleRegisteredEvent = createModuleRegisteredEvent(moduleAddress, moduleName, moduleDescription); + + handleModuleRegistered(moduleRegisteredEvent); + + assert.entityCount("Module", 1); + + assert.fieldEquals("Module", "0x" + moduleAddress, "id", "0x" + moduleAddress); + assert.fieldEquals("Module", "0x" + moduleAddress, "name", moduleName); + assert.fieldEquals("Module", "0x" + moduleAddress, "description", moduleDescription); + assert.fieldEquals("Module", "0x" + moduleAddress, "moduleAddress", "0x" + moduleAddress); + }); + + test("Should increment the modules Counter", () => { + assert.entityCount("Module", 0); + + const moduleAddress1 = "f75be6f9418710fd516fa82afb3aad07e11a0f1b"; + const moduleAddress2 = "e75be6f9418710fd516fa82afb3aad07e11a0f1b"; + + const moduleRegisteredEvent1 = createModuleRegisteredEvent(moduleAddress1, moduleName, moduleDescription); + + handleModuleRegistered(moduleRegisteredEvent1); + + assert.entityCount("Module", 1); + assert.fieldEquals("Counter", "counter", "modules", "1"); + + const moduleRegisteredEvent2 = createModuleRegisteredEvent(moduleAddress2, moduleName, moduleDescription); + + handleModuleRegistered(moduleRegisteredEvent2); + + assert.entityCount("Module", 2); + assert.fieldEquals("Counter", "counter", "modules", "2"); + }); +}); + +function createModuleRegisteredEvent( + moduleAddress: string, + moduleName: string, + moduleDescription: string, +): ModuleRegistered { + const moduleRegisteredEvent = newTypedMockEvent(); + + moduleRegisteredEvent.parameters.push(new ethereum.EventParam("name", ethereum.Value.fromString(moduleName))); + moduleRegisteredEvent.parameters.push( + new ethereum.EventParam("description", ethereum.Value.fromString(moduleDescription)), + ); + moduleRegisteredEvent.parameters.push( + new ethereum.EventParam("moduleAddress", ethereum.Value.fromAddress(Address.fromString(moduleAddress))), + ); + + return moduleRegisteredEvent; +} diff --git a/subgraph/tests/portal-registry.test.ts b/subgraph/tests/portal-registry.test.ts new file mode 100644 index 00000000..fe635e83 --- /dev/null +++ b/subgraph/tests/portal-registry.test.ts @@ -0,0 +1,101 @@ +import { afterEach, assert, beforeAll, clearStore, createMockedFunction, describe, log, test } from "matchstick-as"; +import { Address, ethereum } from "@graphprotocol/graph-ts"; +import { PortalRegistry } from "../generated/PortalRegistry/PortalRegistry"; + +const portalRegistryAddress = Address.fromString("506f88a5Ca8D5F001f2909b029738A40042e42a6"); + +describe("handlePortalRegistered()", () => { + const portalAddress = "f75be6f9418710fd516fa82afb3aad07e11a0f1b"; + const ownerAddress = "e75be6f9418710fd516fa82afb3aad07e11a0f1b"; + const ownerName = "Verax"; + const portalName = "portal name"; + const portalDescription = "portal description"; + const portalTupleArray: Array = [ + ethereum.Value.fromAddress(Address.fromString(portalAddress)), + ethereum.Value.fromAddress(Address.fromString(ownerAddress)), + ethereum.Value.fromAddressArray([Address.zero()]), + ethereum.Value.fromBoolean(true), + ethereum.Value.fromString(portalName), + ethereum.Value.fromString(portalDescription), + ethereum.Value.fromString(ownerName), + ]; + //const portalTuple = changetype(portalTupleArray); + const portalTupleValue = ethereum.Value.fromTuple(portalTupleArray as ethereum.Tuple); + + beforeAll(() => { + createMockedFunction( + portalRegistryAddress, + "getPortalByAddress", + "getPortalByAddress(address):((address,address,address[],bool,string,string,string))", + ) + .withArgs([ethereum.Value.fromAddress(Address.fromString(portalAddress))]) + .returns([portalTupleValue]); + }); + + afterEach(() => { + clearStore(); + }); + + test("Should mock the call to the PortalRegistry", () => { + log.info(Address.fromString(portalAddress).toHexString(), []); + log.info(portalTupleValue.toString(), []); + const contract = PortalRegistry.bind(Address.fromString(portalAddress)); + const result = contract.getPortalByAddress(Address.fromString(portalAddress)); + + assert.tupleEquals(portalTuple, result); + }); + + /*test("Should create a new Portal entity", () => { + assert.entityCount("Portal", 0); + + const portalRegisteredEvent = createPortalRegisteredEvent(portalAddress, portalName, portalDescription); + + handlePortalRegistered(portalRegisteredEvent); + + assert.entityCount("Portal", 1); + + assert.fieldEquals("Portal", "0x" + portalAddress, "id", "0x" + portalAddress); + assert.fieldEquals("Portal", "0x" + portalAddress, "name", portalName); + assert.fieldEquals("Portal", "0x" + portalAddress, "description", portalDescription); + }); + + test("Should increment the portals Counter", () => { + assert.entityCount("Portal", 0); + + const portalAddress1 = "f75be6f9418710fd516fa82afb3aad07e11a0f1b"; + const portalAddress2 = "e75be6f9418710fd516fa82afb3aad07e11a0f1b"; + + const portalRegisteredEvent1 = createPortalRegisteredEvent(portalAddress1, portalName, portalDescription); + + handlePortalRegistered(portalRegisteredEvent1); + + assert.entityCount("Portal", 1); + assert.fieldEquals("Counter", "counter", "portals", "1"); + + const portalRegisteredEvent2 = createPortalRegisteredEvent(portalAddress2, portalName, portalDescription); + + handlePortalRegistered(portalRegisteredEvent2); + + assert.entityCount("Portal", 2); + assert.fieldEquals("Counter", "counter", "portals", "2"); + });*/ +}); + +/*function createPortalRegisteredEvent( + portalAddress: string, + portalName: string, + portalDescription: string, +): PortalRegisteredEvent { + const portalRegisteredEvent = newTypedMockEvent(); + portalRegisteredEvent.address = portalRegistryAddress; + + portalRegisteredEvent.parameters.push(new ethereum.EventParam("name", ethereum.Value.fromString(portalName))); + portalRegisteredEvent.parameters.push( + new ethereum.EventParam("description", ethereum.Value.fromString(portalDescription)), + ); + portalRegisteredEvent.parameters.push( + new ethereum.EventParam("portalAddress", ethereum.Value.fromAddress(Address.fromString(portalAddress))), + ); + + return portalRegisteredEvent; +}*/ diff --git a/subgraph/tests/schema-registry.test.ts b/subgraph/tests/schema-registry.test.ts new file mode 100644 index 00000000..7362c056 --- /dev/null +++ b/subgraph/tests/schema-registry.test.ts @@ -0,0 +1,94 @@ +import { afterEach, assert, clearStore, describe, test } from "matchstick-as"; +import { Bytes, ethereum } from "@graphprotocol/graph-ts"; +import { newTypedMockEvent } from "matchstick-as/assembly/defaults"; +import { handleSchemaCreated } from "../src/schema-registry"; +import { SchemaCreated, SchemaCreated as SchemaCreatedEvent } from "../generated/SchemaRegistry/SchemaRegistry"; + +describe("handleSchemaCreated()", () => { + const schemaId = "0x7930a5ebfabdd4ef76bbb8cdcbc2225b6256d9511d9cf5ff0d6514c1bdb4d7dc"; + const schemaName = "module name"; + const schemaDescription = "module description"; + const schemaContext = "schema context"; + const schemaString = "(bool isBuilder)"; + + afterEach(() => { + clearStore(); + }); + + test("Should create a new Schema entity", () => { + assert.entityCount("Schema", 0); + + const schemaCreatedEvent = createSchemaCreatedEvent( + schemaId, + schemaName, + schemaDescription, + schemaContext, + schemaString, + ); + + handleSchemaCreated(schemaCreatedEvent); + + assert.entityCount("Schema", 1); + + assert.fieldEquals("Schema", schemaId, "id", schemaId); + assert.fieldEquals("Schema", schemaId, "name", schemaName); + assert.fieldEquals("Schema", schemaId, "description", schemaDescription); + assert.fieldEquals("Schema", schemaId, "context", schemaContext); + assert.fieldEquals("Schema", schemaId, "schema", schemaString); + }); + + test("Should increment the schemas Counter", () => { + assert.entityCount("Schema", 0); + + const schemaId1 = "0x7930a5ebfabdd4ef76bbb8cdcbc2225b6256d9511d9cf5ff0d6514c1bdb4d7dc"; + const schemaId2 = "0x8930a5ebfabdd4ef76bbb8cdcbc2225b6256d9511d9cf5ff0d6514c1bdb4d7dc"; + + const schemaCreatedEvent1 = createSchemaCreatedEvent( + schemaId1, + schemaName, + schemaDescription, + schemaContext, + schemaString, + ); + + handleSchemaCreated(schemaCreatedEvent1); + + assert.entityCount("Schema", 1); + assert.fieldEquals("Counter", "counter", "schemas", "1"); + + const schemaCreatedEvent2 = createSchemaCreatedEvent( + schemaId2, + schemaName, + schemaDescription, + schemaContext, + schemaString, + ); + + handleSchemaCreated(schemaCreatedEvent2); + + assert.entityCount("Schema", 2); + assert.fieldEquals("Counter", "counter", "schemas", "2"); + }); +}); + +function createSchemaCreatedEvent( + schemaId: string, + schemaName: string, + schemaDescription: string, + schemaContext: string, + schemaString: string, +): SchemaCreated { + const schemaCreatedEvent = newTypedMockEvent(); + + schemaCreatedEvent.parameters.push( + new ethereum.EventParam("id", ethereum.Value.fromBytes(Bytes.fromHexString(schemaId))), + ); + schemaCreatedEvent.parameters.push(new ethereum.EventParam("name", ethereum.Value.fromString(schemaName))); + schemaCreatedEvent.parameters.push( + new ethereum.EventParam("description", ethereum.Value.fromString(schemaDescription)), + ); + schemaCreatedEvent.parameters.push(new ethereum.EventParam("context", ethereum.Value.fromString(schemaContext))); + schemaCreatedEvent.parameters.push(new ethereum.EventParam("schemaString", ethereum.Value.fromString(schemaString))); + + return schemaCreatedEvent; +} diff --git a/subgraph/tsconfig.json b/subgraph/tsconfig.json index a6d2ae82..4e866720 100644 --- a/subgraph/tsconfig.json +++ b/subgraph/tsconfig.json @@ -1,3 +1,4 @@ { - "extends": "@graphprotocol/graph-ts/types/tsconfig.base.json" + "extends": "@graphprotocol/graph-ts/types/tsconfig.base.json", + "include": ["src", "tests"] }