not following to get claims for given user/role orgnization unit
yes - i did morethan 10 times it giving same error on devlopment - here the log file
2021-05-26 13:49:35.473 -04:00 [INF] Authorization was successful. 2021-05-26 13:49:35.474 -04:00 [INF] Entity Framework Core 5.0.5 initialized 'SettingManagementDbContext' using provider 'Oracle.EntityFrameworkCore' with options: QuerySplittingBehavior=SplitQuery 2021-05-26 13:49:35.477 -04:00 [INF] Executed DbCommand (2ms) [Parameters=[:name_0='?' (Size = 128), :providerName_1='?' (Size = 64)], CommandType='"Text"', CommandTimeout='0'] SELECT "s"."Id", "s"."Name", "s"."ProviderKey", "s"."ProviderName", "s"."Value" FROM "IDM"."Settings" "s" WHERE (((("s"."Name" = :name_0) AND ("s"."ProviderName" = :providerName_1))) AND ("s"."ProviderKey" IS NULL)) ORDER BY "s"."Id" FETCH FIRST 1 ROWS ONLY 2021-05-26 13:49:35.478 -04:00 [INF] Executed DbCommand (1ms) [Parameters=[:name_0='?' (Size = 128), :providerName_1='?' (Size = 64)], CommandType='"Text"', CommandTimeout='0'] SELECT "s"."Id", "s"."Name", "s"."ProviderKey", "s"."ProviderName", "s"."Value" FROM "IDM"."Settings" "s" WHERE (((("s"."Name" = :name_0) AND ("s"."ProviderName" = :providerName_1))) AND ("s"."ProviderKey" IS NULL)) ORDER BY "s"."Id" FETCH FIRST 1 ROWS ONLY 2021-05-26 13:49:35.479 -04:00 [INF] Executed DbCommand (1ms) [Parameters=[:name_0='?' (Size = 128), :providerName_1='?' (Size = 64)], CommandType='"Text"', CommandTimeout='0'] SELECT "s"."Id", "s"."Name", "s"."ProviderKey", "s"."ProviderName", "s"."Value" FROM "IDM"."Settings" "s" WHERE (((("s"."Name" = :name_0) AND ("s"."ProviderName" = :providerName_1))) AND ("s"."ProviderKey" IS NULL)) ORDER BY "s"."Id" FETCH FIRST 1 ROWS ONLY 2021-05-26 13:49:35.481 -04:00 [INF] Executed DbCommand (1ms) [Parameters=[:name_0='?' (Size = 128), :providerName_1='?' (Size = 64)], CommandType='"Text"', CommandTimeout='0'] SELECT "s"."Id", "s"."Name", "s"."ProviderKey", "s"."ProviderName", "s"."Value" FROM "IDM"."Settings" "s" WHERE (((("s"."Name" = :name_0) AND ("s"."ProviderName" = :providerName_1))) AND ("s"."ProviderKey" IS NULL)) ORDER BY "s"."Id" FETCH FIRST 1 ROWS ONLY 2021-05-26 13:49:35.482 -04:00 [INF] Executed DbCommand (1ms) [Parameters=[:name_0='?' (Size = 128), :providerName_1='?' (Size = 64)], CommandType='"Text"', CommandTimeout='0'] SELECT "s"."Id", "s"."Name", "s"."ProviderKey", "s"."ProviderName", "s"."Value" FROM "IDM"."Settings" "s" WHERE (((("s"."Name" = :name_0) AND ("s"."ProviderName" = :providerName_1))) AND ("s"."ProviderKey" IS NULL)) ORDER BY "s"."Id" FETCH FIRST 1 ROWS ONLY 2021-05-26 13:49:35.484 -04:00 [INF] Executed DbCommand (1ms) [Parameters=[:name_0='?' (Size = 128), :providerName_1='?' (Size = 64)], CommandType='"Text"', CommandTimeout='0'] SELECT "s"."Id", "s"."Name", "s"."ProviderKey", "s"."ProviderName", "s"."Value" FROM "IDM"."Settings" "s" WHERE (((("s"."Name" = :name_0) AND ("s"."ProviderName" = :providerName_1))) AND ("s"."ProviderKey" IS NULL)) ORDER BY "s"."Id" FETCH FIRST 1 ROWS ONLY 2021-05-26 13:49:35.485 -04:00 [INF] Executed DbCommand (1ms) [Parameters=[:name_0='?' (Size = 128), :providerName_1='?' (Size = 64)], CommandType='"Text"', CommandTimeout='0'] SELECT "s"."Id", "s"."Name", "s"."ProviderKey", "s"."ProviderName", "s"."Value" FROM "IDM"."Settings" "s" WHERE (((("s"."Name" = :name_0) AND ("s"."ProviderName" = :providerName_1))) AND ("s"."ProviderKey" IS NULL)) ORDER BY "s"."Id" FETCH FIRST 1 ROWS ONLY 2021-05-26 13:49:35.487 -04:00 [INF] Executed DbCommand (1ms) [Parameters=[:name_0='?' (Size = 128), :providerName_1='?' (Size = 64)], CommandType='"Text"', CommandTimeout='0'] SELECT "s"."Id", "s"."Name", "s"."ProviderKey", "s"."ProviderName", "s"."Value" FROM "IDM"."Settings" "s" WHERE (((("s"."Name" = :name_0) AND ("s"."ProviderName" = :providerName_1))) AND ("s"."ProviderKey" IS NULL)) ORDER BY "s"."Id" FETCH FIRST 1 ROWS ONLY 2021-05-26 13:49:35.488 -04:00 [INF] Executed DbCommand (1ms) [Parameters=[:name_0='?' (Size = 128), :providerName_1='?' (Size = 64)], CommandType='"Text"', CommandTimeout='0'] SELECT "s"."Id", "s"."Name", "s"."ProviderKey", "s"."ProviderName", "s"."Value" FROM "IDM"."Settings" "s" WHERE (((("s"."Name" = :name_0) AND ("s"."ProviderName" = :providerName_1))) AND ("s"."ProviderKey" IS NULL)) ORDER BY "s"."Id" FETCH FIRST 1 ROWS ONLY 2021-05-26 13:49:35.488 -04:00 [INF] Entity Framework Core 5.0.5 initialized 'AbpAuditLoggingDbContext' using provider 'Oracle.EntityFrameworkCore' with options: QuerySplittingBehavior=SplitQuery 2021-05-26 13:49:35.492 -04:00 [INF] Executed DbCommand (2ms) [Parameters=[:p0='?' (DbType = Binary), :p1='?' (Size = 96), :p2='?' (Size = 512), :p3='?' (Size = 64), :p4='?' (Size = 64), :p5='?' (Size = 128), :p6='?' (Size = 256), :p7='?' (Size = 40), :p8='?' (Size = 64), :p9='?' (Size = 2000), :p10='?' (DbType = Int32), :p11='?' (DbType = DateTime), :p12='?' (Size = 2000), :p13='?' (Size = 16), :p14='?' (DbType = Int32), :p15='?' (DbType = Binary), :p16='?' (DbType = Binary), :p17='?' (DbType = Binary), :p18='?' (Size = 2000), :p19='?' (Size = 256), :p20='?' (DbType = Binary), :p21='?' (Size = 256)], CommandType='"Text"', CommandTimeout='0'] BEGIN
INSERT INTO "IDM"."AuditLogs" ("Id", "ApplicationName", "BrowserInfo", "ClientId", "ClientIpAddress", "ClientName", "Comments", "ConcurrencyStamp", "CorrelationId", "Exceptions", "ExecutionDuration", "ExecutionTime", "ExtraProperties", "HttpMethod", "HttpStatusCode", "ImpersonatorTenantId", "ImpersonatorUserId", "TenantId", "TenantName", "Url", "UserId", "UserName") VALUES (:p0, :p1, :p2, :p3, :p4, :p5, :p6, :p7, :p8, :p9, :p10, :p11, :p12, :p13, :p14, :p15, :p16, :p17, :p18, :p19, :p20, :p21); END; 2021-05-26 13:49:35.495 -04:00 [INF] Executed DbCommand (2ms) [Parameters=[:p22='?' (DbType = Binary), :p23='?' (DbType = Binary), :p24='?' (DbType = Int32), :p25='?' (DbType = DateTime), :p26='?' (Size = 2000), :p27='?' (Size = 128), :p28='?' (Size = 2000), :p29='?' (Size = 256), :p30='?' (DbType = Binary)], CommandType='"Text"', CommandTimeout='0'] BEGIN
INSERT INTO "IDM"."AuditLogActions" ("Id", "AuditLogId", "ExecutionDuration", "ExecutionTime", "ExtraProperties", "MethodName", "Parameters", "ServiceName", "TenantId") VALUES (:p22, :p23, :p24, :p25, :p26, :p27, :p28, :p29, :p30); END; 2021-05-26 13:49:35.501 -04:00 [ERR] 2021-05-26 13:49:35.501753 ThreadID:20 (ERROR) OracleRelationalCommand.ExecuteReaderAsync() : Oracle.ManagedDataAccess.Client.OracleException (0x80004005): ORA-01400: cannot insert NULL into ("IDM"."Settings"."Value") ORA-06512: at line 3 at OracleInternal.ServiceObjects.OracleConnectionImpl.VerifyExecution(Int32& cursorId, Boolean bThrowArrayBindRelatedErrors, SqlStatementType sqlStatementType, Int32 arrayBindCount, OracleException& exceptionForArrayBindDML, Boolean& hasMoreRowsInDB, Boolean bFirstIterationDone) at OracleInternal.ServiceObjects.OracleCommandImpl.VerifyExecution(OracleConnectionImpl connectionImpl, Int32& cursorId, Boolean bThrowArrayBindRelatedErrors, OracleException& exceptionForArrayBindDML, Boolean& hasMoreRowsInDB, Boolean bFirstIterationDone) at OracleInternal.ServiceObjects.OracleCommandImpl.ExecuteReader(String commandText, OracleParameterCollection paramColl, CommandType commandType, OracleConnectionImpl connectionImpl, OracleDataReaderImpl& rdrImpl, Int32 longFetchSize, Int64 clientInitialLOBFS, OracleDependencyImpl orclDependencyImpl, Int64[] scnForExecution, Int64[]& scnFromExecution, OracleParameterCollection& bindByPositionParamColl, Boolean& bBindParamPresent, Int64& internalInitialLOBFS, Int64 internalInitialJSONFS, OracleException& exceptionForArrayBindDML, OracleConnection connection, OracleLogicalTransaction& oracleLogicalTransaction, IEnumerable`1 adrianParsedStmt, Boolean isDescribeOnly, Boolean isFromEF) at Oracle.ManagedDataAccess.Client.OracleCommand.ExecuteReader(Boolean requery, Boolean fillRequest, CommandBehavior behavior) at Oracle.ManagedDataAccess.Client.OracleCommand.ExecuteDbDataReader(CommandBehavior behavior) at System.Data.Common.DbCommand.ExecuteDbDataReaderAsync(CommandBehavior behavior, CancellationToken cancellationToken) --- End of stack trace from previous location --- at Oracle.EntityFrameworkCore.Storage.Internal.OracleRelationalCommandBuilderFactory.OracleRelationalCommandBuilder.OracleRelationalCommand.ExecuteReaderAsync(RelationalCommandParameterObject parameterObject, CancellationToken cancellationToken) 2021-05-26 13:49:35.501 -04:00 [ERR] Failed executing DbCommand (2ms) [Parameters=[:p0='?' (DbType = Binary), :p1='?' (Size = 128), :p2='?' (Size = 64), :p3='?' (Size = 64), :p4='?' (Size = 2000), :p5='?' (DbType = Binary), :p6='?' (Size = 128), :p7='?' (Size = 64), :p8='?' (Size = 64), :p9='?' (Size = 2000), :p10='?' (DbType = Binary), :p11='?' (Size = 128), :p12='?' (Size = 64), :p13='?' (Size = 64), :p14='?' (Size = 2000), :p15='?' (DbType = Binary), :p16='?' (Size = 128), :p17='?' (Size = 64), :p18='?' (Size = 64), :p19='?' (Size = 2000)], CommandType='"Text"', CommandTimeout='0'] BEGIN
INSERT INTO "IDM"."Settings" ("Id", "Name", "ProviderKey", "ProviderName", "Value")
VALUES (:p0, :p1, :p2, :p3, :p4);
INSERT INTO "IDM"."Settings" ("Id", "Name", "ProviderKey", "ProviderName", "Value")
VALUES (:p5, :p6, :p7, :p8, :p9);
INSERT INTO "IDM"."Settings" ("Id", "Name", "ProviderKey", "ProviderName", "Value")
VALUES (:p10, :p11, :p12, :p13, :p14);
INSERT INTO "IDM"."Settings" ("Id", "Name", "ProviderKey", "ProviderName", "Value")
VALUES (:p15, :p16, :p17, :p18, :p19);
END;
2021-05-26 13:49:35.503 -04:00 [ERR] An error occurred using a transaction.
2021-05-26 13:49:35.504 -04:00 [ERR] 2021-05-26 13:49:35.504688 ThreadID:20 (ERROR) OracleExecutionStrategy.ExecuteAsync() : Microsoft.EntityFrameworkCore.DbUpdateException: An error occurred while updating the entries. See the inner exception for details.
---> Oracle.ManagedDataAccess.Client.OracleException (0x80004005): ORA-01400: cannot insert NULL into ("IDM"."Settings"."Value")
ORA-06512: at line 3
at OracleInternal.ServiceObjects.OracleConnectionImpl.VerifyExecution(Int32& cursorId, Boolean bThrowArrayBindRelatedErrors, SqlStatementType sqlStatementType, Int32 arrayBindCount, OracleException& exceptionForArrayBindDML, Boolean& hasMoreRowsInDB, Boolean bFirstIterationDone)
at OracleInternal.ServiceObjects.OracleCommandImpl.VerifyExecution(OracleConnectionImpl connectionImpl, Int32& cursorId, Boolean bThrowArrayBindRelatedErrors, OracleException& exceptionForArrayBindDML, Boolean& hasMoreRowsInDB, Boolean bFirstIterationDone)
at OracleInternal.ServiceObjects.OracleCommandImpl.ExecuteReader(String commandText, OracleParameterCollection paramColl, CommandType commandType, OracleConnectionImpl connectionImpl, OracleDataReaderImpl& rdrImpl, Int32 longFetchSize, Int64 clientInitialLOBFS, OracleDependencyImpl orclDependencyImpl, Int64[] scnForExecution, Int64[]& scnFromExecution, OracleParameterCollection& bindByPositionParamColl, Boolean& bBindParamPresent, Int64& internalInitialLOBFS, Int64 internalInitialJSONFS, OracleException& exceptionForArrayBindDML, OracleConnection connection, OracleLogicalTransaction& oracleLogicalTransaction, IEnumerable1 adrianParsedStmt, Boolean isDescribeOnly, Boolean isFromEF) at Oracle.ManagedDataAccess.Client.OracleCommand.ExecuteReader(Boolean requery, Boolean fillRequest, CommandBehavior behavior) at Oracle.ManagedDataAccess.Client.OracleCommand.ExecuteDbDataReader(CommandBehavior behavior) at System.Data.Common.DbCommand.ExecuteDbDataReaderAsync(CommandBehavior behavior, CancellationToken cancellationToken) --- End of stack trace from previous location --- at Oracle.EntityFrameworkCore.Storage.Internal.OracleRelationalCommandBuilderFactory.OracleRelationalCommandBuilder.OracleRelationalCommand.ExecuteReaderAsync(RelationalCommandParameterObject parameterObject, CancellationToken cancellationToken) at Oracle.EntityFrameworkCore.Storage.Internal.OracleRelationalCommandBuilderFactory.OracleRelationalCommandBuilder.OracleRelationalCommand.ExecuteReaderAsync(RelationalCommandParameterObject parameterObject, CancellationToken cancellationToken) at Oracle.EntityFrameworkCore.Storage.Internal.OracleRelationalCommandBuilderFactory.OracleRelationalCommandBuilder.OracleRelationalCommand.ExecuteReaderAsync(RelationalCommandParameterObject parameterObject, CancellationToken cancellationToken) at Microsoft.EntityFrameworkCore.Update.ReaderModificationCommandBatch.ExecuteAsync(IRelationalConnection connection, CancellationToken cancellationToken) --- End of inner exception stack trace --- at Microsoft.EntityFrameworkCore.Update.ReaderModificationCommandBatch.ExecuteAsync(IRelationalConnection connection, CancellationToken cancellationToken) at Microsoft.EntityFrameworkCore.Update.Internal.BatchExecutor.ExecuteAsync(IEnumerable
1 commandBatches, IRelationalConnection connection, CancellationToken cancellationToken)
at Microsoft.EntityFrameworkCore.Update.Internal.BatchExecutor.ExecuteAsync(IEnumerable1 commandBatches, IRelationalConnection connection, CancellationToken cancellationToken) at Microsoft.EntityFrameworkCore.Update.Internal.BatchExecutor.ExecuteAsync(IEnumerable
1 commandBatches, IRelationalConnection connection, CancellationToken cancellationToken)
at Microsoft.EntityFrameworkCore.ChangeTracking.Internal.StateManager.SaveChangesAsync(IList1 entriesToSave, CancellationToken cancellationToken) at Microsoft.EntityFrameworkCore.ChangeTracking.Internal.StateManager.SaveChangesAsync(DbContext _, Boolean acceptAllChangesOnSuccess, CancellationToken cancellationToken) at Oracle.EntityFrameworkCore.Storage.Internal.OracleExecutionStrategy.ExecuteAsync[TState,TResult](TState state, Func
4 operation, Func4 verifySucceeded, CancellationToken cancellationToken) 2021-05-26 13:49:35.505 -04:00 [ERR] An exception occurred in the database while saving changes for context type 'Volo.Abp.SettingManagement.EntityFrameworkCore.SettingManagementDbContext'. Microsoft.EntityFrameworkCore.DbUpdateException: An error occurred while updating the entries. See the inner exception for details. ---> Oracle.ManagedDataAccess.Client.OracleException (0x80004005): ORA-01400: cannot insert NULL into ("IDM"."Settings"."Value") ORA-06512: at line 3 at OracleInternal.ServiceObjects.OracleConnectionImpl.VerifyExecution(Int32& cursorId, Boolean bThrowArrayBindRelatedErrors, SqlStatementType sqlStatementType, Int32 arrayBindCount, OracleException& exceptionForArrayBindDML, Boolean& hasMoreRowsInDB, Boolean bFirstIterationDone) at OracleInternal.ServiceObjects.OracleCommandImpl.VerifyExecution(OracleConnectionImpl connectionImpl, Int32& cursorId, Boolean bThrowArrayBindRelatedErrors, OracleException& exceptionForArrayBindDML, Boolean& hasMoreRowsInDB, Boolean bFirstIterationDone) at OracleInternal.ServiceObjects.OracleCommandImpl.ExecuteReader(String commandText, OracleParameterCollection paramColl, CommandType commandType, OracleConnectionImpl connectionImpl, OracleDataReaderImpl& rdrImpl, Int32 longFetchSize, Int64 clientInitialLOBFS, OracleDependencyImpl orclDependencyImpl, Int64[] scnForExecution, Int64[]& scnFromExecution, OracleParameterCollection& bindByPositionParamColl, Boolean& bBindParamPresent, Int64& internalInitialLOBFS, Int64 internalInitialJSONFS, OracleException& exceptionForArrayBindDML, OracleConnection connection, OracleLogicalTransaction& oracleLogicalTransaction, IEnumerable
1 adrianParsedStmt, Boolean isDescribeOnly, Boolean isFromEF)
at Oracle.ManagedDataAccess.Client.OracleCommand.ExecuteReader(Boolean requery, Boolean fillRequest, CommandBehavior behavior)
at Oracle.ManagedDataAccess.Client.OracleCommand.ExecuteDbDataReader(CommandBehavior behavior)
at System.Data.Common.DbCommand.ExecuteDbDataReaderAsync(CommandBehavior behavior, CancellationToken cancellationToken)
--- End of stack trace from previous location ---
at
for IDM API.
{
"App": {
"SelfUrl": "https://dev-idm.testdomain.com/idmapi/",
"AngularUrl": "http://localhost:4200",
"MVCPublicUrl": "https://localhost:44306",
"CorsOrigins": "https://.testdomain.com"
},
"ConnectionStrings": {
"Default": ""
},
"Redis": {
"Configuration": "127.0.0.1"
},
"AuthServer": {
"Authority": "https://dev-ids.testdomain.com",
"RequireHttpsMetadata": "true",
"SwaggerClientId": "IdentityManager_Swagger",
"SwaggerClientSecret": "1q2w3e"
},
"StringEncryption": {
"DefaultPassPhrase": "KdJ301s5dk73YlJq"
},
"Settings": {
"Abp.Mailing.Smtp.Host": "1",
"Abp.Mailing.DefaultFromAddress": "",
"Abp.Mailing.DefaultFromDisplayName": "",
"Volo.Abp.LeptonTheme.Style": "Style6", /* Options: Style1, Style2... Style6 /
"Volo.Abp.LeptonTheme.Layout.MenuPlacement": "Left", / Options: Left, Top /
"Volo.Abp.LeptonTheme.Layout.MenuStatus": "AlwaysOpened", / Options: AlwaysOpened, OpenOnHover /
"Volo.Abp.LeptonTheme.Layout.Boxed": "False" / Options: True, False */
},
"AbpLicenseCode": ""
}
for IDS { "App": { "SelfUrl": "https://dev-ids.testdomain.com", "CorsOrigins": "https://.testdomain.com,http://localhost:4200,https://localhost:44357,https://localhost:44398,https://localhost:44307,https://localhost:44350,http://localhost:4205,https://localhost:44300,http://localhost:50500,https://dev-idm.testdomain.com,https://localhost:44310,https://localhost://44350", "RedirectAllowedUrls": "http://localhost:4200,https://localhost:44307,https://localhost://44310,https://localhost:44357,https://localhost:44398" }, "ConnectionStrings": { "Default": "" }, "StringEncryption": { "DefaultPassPhrase": "KdJ301s5dk73YlJq" }, "Settings": { "Abp.Identity.TwoFactor.Behaviour": "Forced", "Abp.Account.TwoFactorLogin.IsRememberBrowserEnabled": "True", "Abp.Identity.SignIn.EnablePhoneNumberConfirmation": "False", "Abp.Account.IsSelfRegistrationEnabled": "True", / "Abp.Account.EnableLocalLogin": "False",/ "Abp.Mailing.Smtp.Host": ", "Abp.Mailing.DefaultFromAddress": "", "Abp.Mailing.DefaultFromDisplayName": "", "Volo.Abp.LeptonTheme.Style": "Style6", / Options: Style1, Style2... Style6 / "Volo.Abp.LeptonTheme.Layout.MenuPlacement": "Left", / Options: Left, Top / "Volo.Abp.LeptonTheme.Layout.MenuStatus": "AlwaysOpened", / Options: AlwaysOpened, OpenOnHover / "Volo.Abp.LeptonTheme.Layout.Boxed": "False" / Options: True, False */ }, "AzureAd": { "Instance": "https://login.microsoftonline.com/", "TenantId": "", "ClientId": "", "ClientSecret": "", "CallbackPath": "/signin-azuread-oidc" }, "Redis": { "Configuration": "127.0.0.1" }, "AbpLicenseCode": "" }
<?xml version="1.0" encoding="utf-8"?> <configuration> <location path="." inheritInChildApplications="false"> <system.webServer> <handlers> <add name="aspNetCore" path="" verb="" modules="AspNetCoreModuleV2" resourceType="Unspecified" /> </handlers> <aspNetCore processPath=".\Mcp.IdentityManager.Web.exe" stdoutLogEnabled="false" stdoutLogFile=".\logs\stdout" hostingModel="InProcess" /> </system.webServer> </location> </configuration> <!--ProjectGuid: 6FE54035-9C11-4702-A5E2-D16F23101468-->
{
"App": {
"SelfUrl": "https://dev-idm.testdomain.com"
},
"RemoteServices": {
"Default": {
"BaseUrl": "https://dev-idm.testdomain/idmapi/"
}
},
"Redis": {
"Configuration": "127.0.0.1"
},
"AuthServer": {
"Authority": "https://dev-ids.testdomain.com/",
"RequireHttpsMetadata": "true",
"ClientId": "IdentityManager_Web",
"ClientSecret": "1q2w3e*"
},
"StringEncryption": {
"DefaultPassPhrase": "KdJ301s5dk73YlJq"
},
"AbpLicenseCode": ""
}
hi you need web.confg or appsetting
i done all table prefix - only missing is "AbpPermissionGrants".. unable to set prefix ? please help me on this?
i done all table prefix - only missing is "AbpPermissionGrants".. unable to set prefix ? please help me on this?
so how can get my cutom propertiy if have added as USER_ID_NH (DEFAULT SEQ),, Then get this value from token
let say if have added USER_ID AS CUSTOM FILED, this can get from token as token claims
it is not working as tested