Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add DealSponsored event handler #23

Merged
merged 54 commits into from
Dec 13, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
54 commits
Select commit Hold shift + click to select a range
a8ef9ad
udpate poco subgraph to deal with sponsored MO
gfournieriExec Nov 20, 2024
3066697
deploy local graphnode with setting a particular starting block
gfournieriExec Nov 26, 2024
779569a
update timeout
gfournieriExec Nov 27, 2024
86f747d
test its
gfournieriExec Nov 27, 2024
e4a0c39
separate docker local test and it test
gfournieriExec Nov 27, 2024
e83569a
get back all vesion
gfournieriExec Nov 27, 2024
bf31ccc
add end of file line
gfournieriExec Nov 27, 2024
909e869
update timeout
gfournieriExec Nov 27, 2024
f38a77b
update waiting seconds
gfournieriExec Nov 27, 2024
ff7c1a7
remve console log
gfournieriExec Nov 27, 2024
b4582d4
re-add seconds
gfournieriExec Nov 27, 2024
7cf21ad
remove console log
gfournieriExec Nov 27, 2024
ab8d12b
Merge branch 'feature/local-test' into feature/poco-sponsoring
gfournieriExec Nov 28, 2024
8221169
update packages
gfournieriExec Nov 28, 2024
732876f
remove un necessary file
gfournieriExec Nov 28, 2024
4adf814
rest old files and update poco package
gfournieriExec Nov 28, 2024
9ae5fcb
update iexec solidity package version
gfournieriExec Nov 28, 2024
282fee6
update schema
gfournieriExec Nov 28, 2024
1fe6d7e
change dealId to deal
gfournieriExec Nov 28, 2024
09714cf
expose handleDealSponsored
gfournieriExec Nov 28, 2024
e5e2153
remove formating
gfournieriExec Nov 28, 2024
f1338ba
update header
gfournieriExec Nov 28, 2024
6d21031
update header
gfournieriExec Nov 28, 2024
c5dc4c3
Create UT for DealSponsored
gfournieriExec Nov 28, 2024
95caf7f
test set timout and wait seconds back
gfournieriExec Nov 28, 2024
6cde1a8
set back 10 seconds
gfournieriExec Nov 28, 2024
cfa1b6e
Merge branch 'feature/formatting-sponsor' into feature/poco-sponsoring
gfournieriExec Dec 9, 2024
2a2653a
Merge branch 'develop' into feature/poco-sponsoring
gfournieriExec Dec 10, 2024
becc924
test add git in jenkins IT
gfournieriExec Dec 10, 2024
a198c31
remove install git from docker
gfournieriExec Dec 10, 2024
2b5ca07
set back
gfournieriExec Dec 10, 2024
0e5e74e
update test
gfournieriExec Dec 11, 2024
c0cae68
add blank line
gfournieriExec Dec 11, 2024
5e146f4
update to dealId
gfournieriExec Dec 11, 2024
6d47957
update test
gfournieriExec Dec 12, 2024
5543087
load event to prevent re-indexing trick
gfournieriExec Dec 12, 2024
adf93ca
set only husky if not CI
gfournieriExec Dec 12, 2024
63b78c6
nest false
gfournieriExec Dec 12, 2024
f1859ed
test
gfournieriExec Dec 12, 2024
c756e49
remove git intstall
gfournieriExec Dec 12, 2024
cefcb2b
set husky not in CI
gfournieriExec Dec 12, 2024
783245b
get logs
gfournieriExec Dec 12, 2024
352be55
invert the logic to test
gfournieriExec Dec 12, 2024
d821747
set else
gfournieriExec Dec 12, 2024
43c7b55
test bullshit
gfournieriExec Dec 12, 2024
c174b25
update
gfournieriExec Dec 12, 2024
5cfc1e7
rest prepare
gfournieriExec Dec 12, 2024
0d99128
update test prepare
gfournieriExec Dec 12, 2024
bfe1942
update package.json
gfournieriExec Dec 12, 2024
e0efce4
update dealID to deal to match interface
gfournieriExec Dec 12, 2024
697376e
set prepare back to husky no impact
gfournieriExec Dec 13, 2024
bb34272
test without git
gfournieriExec Dec 13, 2024
83ba20f
wait 5 minutes
gfournieriExec Dec 13, 2024
508680d
debug option to have testcontainer logs
gfournieriExec Dec 13, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 0 additions & 1 deletion docker/Dockerfile
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
FROM node:22
WORKDIR /iexec-poco-subgraph
RUN apt-get update && apt-get install -y git
COPY package*.json .
RUN npm ci
COPY schema.graphql .
Expand Down
2 changes: 1 addition & 1 deletion itest/integration.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ describe('Integration tests', () => {
before(async () => {
console.log('Starting services..');
const environment = new DockerComposeEnvironment('docker/test/', 'docker-compose.yml')
.withStartupTimeout(3 * MINUTES)
.withStartupTimeout(5 * MINUTES)
.withWaitStrategy(
'poco-subgraph-deployer-1',
Wait.forLogMessage(
Expand Down
81 changes: 36 additions & 45 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

7 changes: 4 additions & 3 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,8 @@
"create": "graph create ${NETWORK_NAME:-bellecour}/poco --node ${GRAPHNODE_URL:-http://localhost:8020}",
"deploy": "graph deploy ${NETWORK_NAME:-bellecour}/poco --node ${GRAPHNODE_URL:-http://localhost:8020} --ipfs ${IPFS_URL:-http://localhost:5001} --version-label ${VERSION_LABEL:-bellecour/poco-v5}",
"deploy:all": "npm run build && npm run create && npm run deploy",
"itest": "DEBUG=:* mocha"
"itest": "DEBUG=testcontainers:* mocha"

},
"lint-staged": {
"*.{js,ts}": [
Expand Down Expand Up @@ -41,7 +42,7 @@
"testcontainers": "^10.13.2"
},
"dependencies": {
"@iexec/poco": "5.3.0",
"@iexec/solidity": "0.1.0"
"@iexec/poco": "^5.5.0",
"@iexec/solidity": "^0.1.1"
}
}
8 changes: 8 additions & 0 deletions schema.graphql
Original file line number Diff line number Diff line change
Expand Up @@ -436,6 +436,14 @@ type OrdersMatched implements DealEvent @entity {
deal: Deal!
}

type DealSponsored implements DealEvent @entity {
id: ID!
transaction: Transaction!
timestamp: BigInt!
deal: Deal!
zguesmi marked this conversation as resolved.
Show resolved Hide resolved
sponsor: Account!
}

interface TaskEvent {
id: ID!
transaction: Transaction!
Expand Down
15 changes: 15 additions & 0 deletions src/Modules/IexecPoco.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@ import { BigInt } from '@graphprotocol/graph-ts';

import {
AccurateContribution as AccurateContributionEvent,
DealSponsored as DealSponsoredEvent,
FaultyContribution as FaultyContributionEvent,
IexecInterfaceToken as IexecInterfaceTokenContract,
MatchOrdersCall,
Expand All @@ -21,6 +22,7 @@ import {

import {
AccurateContribution,
DealSponsored,
FaultyContribution,
OrdersMatched,
SchedulerNotice,
Expand Down Expand Up @@ -421,3 +423,16 @@ export function handleFaultyContribution(event: FaultyContributionEvent): void {
workerAccount.score = faultyContributionEvent.score;
workerAccount.save();
}

export function handleDealSponsored(event: DealSponsoredEvent): void {
zguesmi marked this conversation as resolved.
Show resolved Hide resolved
let dealSponsoredEvent = DealSponsored.load(createEventID(event));
if (!dealSponsoredEvent) {
dealSponsoredEvent = new DealSponsored(createEventID(event));
}
dealSponsoredEvent.transaction = logTransaction(event).id;
dealSponsoredEvent.transaction = logTransaction(event).id;
dealSponsoredEvent.timestamp = event.block.timestamp;
dealSponsoredEvent.deal = event.params.dealId.toHex();
dealSponsoredEvent.sponsor = event.params.sponsor.toHex();
dealSponsoredEvent.save();
}
1 change: 1 addition & 0 deletions src/Modules/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ export { handleLock, handleReward, handleSeize, handleTransfer, handleUnlock } f

export {
handleAccurateContribution,
handleDealSponsored,
handleFaultyContribution,
handleMatchOrders,
handleOrdersMatched,
Expand Down
5 changes: 4 additions & 1 deletion subgraph.template.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -69,9 +69,10 @@ dataSources:
- Seize
- Lock
- Unlock
- DealSponsored
abis:
- name: IexecInterfaceToken
file: node_modules/@iexec/poco/build/contracts/IexecInterfaceNative.json
file: node_modules/@iexec/poco/artifacts/contracts/IexecInterfaceNative.sol/IexecInterfaceNative.json
eventHandlers:
- event: CreateCategory(uint256,string,string,uint256)
handler: handleCreateCategory
Expand Down Expand Up @@ -107,6 +108,8 @@ dataSources:
handler: handleLock
- event: Unlock(address,uint256)
handler: handleUnlock
- event: DealSponsored(bytes32,address)
handler: handleDealSponsored
callHandlers:
- function: matchOrders((address,uint256,uint256,bytes32,address,address,address,bytes32,bytes),(address,uint256,uint256,bytes32,address,address,address,bytes32,bytes),(address,uint256,uint256,bytes32,uint256,uint256,address,address,address,bytes32,bytes),(address,uint256,address,uint256,address,uint256,address,uint256,bytes32,uint256,uint256,address,address,string,bytes32,bytes))
handler: handleMatchOrders
Expand Down
42 changes: 42 additions & 0 deletions test/Modules/IexecPoco.test.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,42 @@
// SPDX-FileCopyrightText: 2024 IEXEC BLOCKCHAIN TECH <[email protected]>
// SPDX-License-Identifier: Apache-2.0

import { Address, BigInt, Bytes, ethereum } from '@graphprotocol/graph-ts';
import { assert, describe, newTypedMockEventWithParams, test } from 'matchstick-as/assembly/index';
import { DealSponsored } from '../../generated/Core/IexecInterfaceToken';
import { handleDealSponsored } from '../../src/Modules';

describe('IexecPoco', () => {
test('Should handle DealSponsored', () => {
// Define mock parameters
const dealId = Bytes.fromHexString(
'0x1234567890abcdef1234567890abcdef1234567890abcdef1234567890abcdef',
);
const sponsor = Address.fromString('0xabcdef1234567890abcdef1234567890abcdef12');
zguesmi marked this conversation as resolved.
Show resolved Hide resolved
const timestamp = BigInt.fromI32(123456789);

// Create the mock event
let mockEvent = newTypedMockEventWithParams<DealSponsored>([
new ethereum.EventParam('deal', ethereum.Value.fromFixedBytes(dealId)),
new ethereum.EventParam('sponsor', ethereum.Value.fromAddress(sponsor)),
]);
mockEvent.block.timestamp = timestamp;

// Call the handler
handleDealSponsored(mockEvent);

// Assert that the DealSponsored entity was created and has correct fields
const entityId = mockEvent.block.number
.toString()
.concat('-')
.concat(mockEvent.logIndex.toString());

assert.fieldEquals('DealSponsored', entityId, 'deal', dealId.toHex());
assert.fieldEquals('DealSponsored', entityId, 'sponsor', sponsor.toHex());
assert.fieldEquals('DealSponsored', entityId, 'timestamp', timestamp.toString());

// Assert that a transaction was logged (if applicable)
const transactionId = mockEvent.transaction.hash.toHex();
assert.fieldEquals('Transaction', transactionId, 'id', transactionId);
});
});
Loading