1
0
mirror of https://github.com/sasjs/adapter.git synced 2026-01-13 07:00:06 +00:00

Compare commits

...

14 Commits

Author SHA1 Message Date
Muhammad Saad
2cffc57209 Merge pull request #259 from sasjs/issue-258
Issue 258
2021-02-25 18:41:21 +05:00
Muhammad Saad
4e43687de2 Merge branch 'master' into issue-258 2021-02-25 18:37:35 +05:00
Muhammad Saad
f8dab83e37 Merge pull request #267 from sasjs/error-handling
chore(error-handling): removed redundant catch block
2021-02-25 18:36:19 +05:00
Yury Shkoda
655af03cf3 chore(error-handling): removed redundant catch block 2021-02-25 15:20:35 +03:00
Krishna Acondy
0aeb201625 Merge branch 'master' into issue-258 2021-02-25 07:59:43 +00:00
Mihajlo Medjedovic
349612a065 Merge branch 'issue-258' of github.com:sasjs/adapter into issue-258 2021-02-24 14:11:12 +01:00
Mihajlo Medjedovic
e48b22128d chore: small fix, error was not beign returned 2021-02-24 14:11:00 +01:00
Krishna Acondy
14dfe4ec51 Merge branch 'master' into issue-258 2021-02-24 12:47:16 +00:00
Mihajlo Medjedovic
e0051bf276 chore: test fixing 2021-02-24 13:15:14 +01:00
Mihajlo Medjedovic
7b72998e1c Merge branches 'issue-258' and 'master' of github.com:sasjs/adapter 2021-02-24 12:57:24 +01:00
Mihajlo Medjedovic
66d02cf1d1 style: lint 2021-02-23 23:01:08 +01:00
Mihajlo Medjedovic
f2c8e40430 chore: cleanup, parseResponse optimization 2021-02-23 22:58:48 +01:00
Mihajlo Medjedovic
4b28ee8e73 style: lint 2021-02-23 22:36:32 +01:00
Mihajlo Medjedovic
c7e54cfe9f fix: web approach login callback and debug issue 2021-02-23 22:36:11 +01:00
6 changed files with 156 additions and 74 deletions

View File

@@ -884,9 +884,7 @@ export class SASViyaApiClient {
waitForResult, waitForResult,
pollOptions, pollOptions,
printPid printPid
).catch((err) => { )
throw prefixMessage(err, 'Error while executing script. ')
})
} }
/** /**

View File

@@ -20,7 +20,8 @@ export class ComputeJobExecutor extends BaseJobExecutor {
const waitForResult = true const waitForResult = true
const expectWebout = true const expectWebout = true
return this.sasViyaApiClient const requestPromise = new Promise((resolve, reject) => {
this.sasViyaApiClient
?.executeComputeJob( ?.executeComputeJob(
sasJob, sasJob,
config.contextName, config.contextName,
@@ -32,23 +33,39 @@ export class ComputeJobExecutor extends BaseJobExecutor {
) )
.then((response) => { .then((response) => {
this.appendRequest(response, sasJob, config.debug) this.appendRequest(response, sasJob, config.debug)
let responseJson
return response.result resolve(response.result)
return responseJson
}) })
.catch(async (e: Error) => { .catch(async (e: Error) => {
if (e instanceof ComputeJobExecutionError) { if (e instanceof ComputeJobExecutionError) {
this.appendRequest(e, sasJob, config.debug) this.appendRequest(e, sasJob, config.debug)
reject(new ErrorResponse(e?.message, e))
} }
if (e instanceof LoginRequiredError) { if (e instanceof LoginRequiredError) {
await loginCallback() await loginCallback()
this.appendWaitingRequest(() => this.appendWaitingRequest(() => {
this.execute(sasJob, data, config, loginRequiredCallback) return this.execute(
sasJob,
data,
config,
loginRequiredCallback
).then(
(res: any) => {
resolve(res)
},
(err: any) => {
reject(err)
}
) )
}
return Promise.reject(new ErrorResponse(e?.message, e))
}) })
} else {
reject(new ErrorResponse(e?.message, e))
}
})
})
return requestPromise
} }
} }

View File

@@ -17,24 +17,52 @@ export class JesJobExecutor extends BaseJobExecutor {
accessToken?: string accessToken?: string
) { ) {
const loginCallback = loginRequiredCallback || (() => Promise.resolve()) const loginCallback = loginRequiredCallback || (() => Promise.resolve())
return await this.sasViyaApiClient
?.executeJob(sasJob, config.contextName, config.debug, data, accessToken) const requestPromise = new Promise((resolve, reject) => {
this.sasViyaApiClient
?.executeJob(
sasJob,
config.contextName,
config.debug,
data,
accessToken
)
.then((response) => { .then((response) => {
this.appendRequest(response, sasJob, config.debug) this.appendRequest(response, sasJob, config.debug)
return response.result resolve(response.result)
}) })
.catch(async (e: Error) => { .catch(async (e: Error) => {
if (e instanceof JobExecutionError) { if (e instanceof JobExecutionError) {
this.appendRequest(e, sasJob, config.debug) this.appendRequest(e, sasJob, config.debug)
reject(new ErrorResponse(e?.message, e))
} }
if (e instanceof LoginRequiredError) { if (e instanceof LoginRequiredError) {
await loginCallback() await loginCallback()
this.appendWaitingRequest(() =>
this.execute(sasJob, data, config, loginRequiredCallback) this.appendWaitingRequest(() => {
return this.execute(
sasJob,
data,
config,
loginRequiredCallback
).then(
(res: any) => {
resolve(res)
},
(err: any) => {
reject(err)
}
) )
}
return Promise.reject(new ErrorResponse(e?.message, e))
}) })
} else {
reject(new ErrorResponse(e?.message, e))
}
})
})
return requestPromise
} }
} }

View File

@@ -7,6 +7,11 @@ import { SASViyaApiClient } from '../SASViyaApiClient'
import { isRelativePath } from '../utils' import { isRelativePath } from '../utils'
import { BaseJobExecutor } from './JobExecutor' import { BaseJobExecutor } from './JobExecutor'
export interface WaitingRequstPromise {
promise: Promise<any> | null
resolve: any
reject: any
}
export class WebJobExecutor extends BaseJobExecutor { export class WebJobExecutor extends BaseJobExecutor {
constructor( constructor(
serverUrl: string, serverUrl: string,
@@ -80,30 +85,51 @@ export class WebJobExecutor extends BaseJobExecutor {
} }
} }
return this.requestClient!.post(apiUrl, formData, undefined) const requestPromise = new Promise((resolve, reject) => {
this.requestClient!.post(apiUrl, formData, undefined)
.then(async (res) => { .then(async (res) => {
if (this.serverType === ServerType.SasViya && config.debug) { if (this.serverType === ServerType.SasViya && config.debug) {
const jsonResponse = await this.parseSasViyaDebugResponse( const jsonResponse = await this.parseSasViyaDebugResponse(
res.result as string res.result as string
) )
this.appendRequest(res, sasJob, config.debug) this.appendRequest(res, sasJob, config.debug)
return jsonResponse resolve(jsonResponse)
} }
this.appendRequest(res, sasJob, config.debug) this.appendRequest(res, sasJob, config.debug)
return res.result resolve(res.result)
}) })
.catch(async (e: Error) => { .catch(async (e: Error) => {
if (e instanceof JobExecutionError) { if (e instanceof JobExecutionError) {
this.appendRequest(e, sasJob, config.debug) this.appendRequest(e, sasJob, config.debug)
reject(new ErrorResponse(e?.message, e))
} }
if (e instanceof LoginRequiredError) { if (e instanceof LoginRequiredError) {
await loginCallback() await loginCallback()
this.appendWaitingRequest(() =>
this.execute(sasJob, data, config, loginRequiredCallback) this.appendWaitingRequest(() => {
) return this.execute(
sasJob,
data,
config,
loginRequiredCallback
).then(
(res: any) => {
resolve(res)
},
(err: any) => {
reject(err)
} }
return Promise.reject(new ErrorResponse(e?.message, e)) )
}) })
} else {
reject(new ErrorResponse(e?.message, e))
}
})
})
return requestPromise
} }
private parseSasViyaDebugResponse = async (response: string) => { private parseSasViyaDebugResponse = async (response: string) => {

View File

@@ -386,6 +386,7 @@ export class RequestClient implements HttpClient {
private parseResponse<T>(response: AxiosResponse<any>) { private parseResponse<T>(response: AxiosResponse<any>) {
const etag = response?.headers ? response.headers['etag'] : '' const etag = response?.headers ? response.headers['etag'] : ''
let parsedResponse let parsedResponse
let includeSAS9Log: boolean = false
try { try {
if (typeof response.data === 'string') { if (typeof response.data === 'string') {
@@ -399,11 +400,20 @@ export class RequestClient implements HttpClient {
} catch { } catch {
parsedResponse = response.data parsedResponse = response.data
} }
includeSAS9Log = true
} }
return {
let responseToReturn: { result: T; etag: any; log?: string } = {
result: parsedResponse as T, result: parsedResponse as T,
etag etag
} }
if (includeSAS9Log) {
responseToReturn.log = response.data
}
return responseToReturn
} }
} }

View File

@@ -29,7 +29,10 @@ describe('SessionManager', () => {
Promise.resolve({ data: sampleResponse }) Promise.resolve({ data: sampleResponse })
) )
const expectedResponse = { etag: '', result: sampleResponse } const expectedResponse = {
etag: '',
result: sampleResponse
}
await expect( await expect(
sessionManager.getVariable( sessionManager.getVariable(