Unit 3 - Practice Quiz

INT222 50 Questions
0 Correct 0 Wrong 50 Left
0/50

1 What is the primary communication protocol used by WebSockets?

A. HTTP
B. TCP
C. UDP
D. FTP

2 Which URL scheme is used for an unencrypted WebSocket connection?

A. wss://
B. ws://
C. ftp://
D. http://

3 Unlike HTTP, a WebSocket connection is:

A. Stateless
B. Unreliable
C. One-way only
D. Full-duplex and persistent

4 Which HTTP header is essential for the WebSocket handshake process?

A. Authorization
B. Upgrade
C. Content-Type
D. Accept

5 In a basic Node.js 'ws' server, which event is triggered when a client connects?

A. open
B. connection
C. connect
D. init

6 Which method is used to send a message from the server to a specific client instance in the 'ws' library?

A. client.write()
B. client.emit()
C. client.send()
D. client.push()

7 What does Socket.IO provide that native WebSockets do not handle automatically?

A. Automatic reconnection and fallback support
B. HTTP requests
C. JSON parsing
D. TCP connections

8 In Socket.IO, how do you send a message to all connected clients?

A. socket.broadcast.emit('msg', data)
B. io.emit('msg', data)
C. socket.emit('msg', data)
D. io.sendToAll(data)

9 Which Socket.IO method is used to send a message to everyone except the sender?

A. socket.send()
B. io.emit()
C. socket.broadcast.emit()
D. socket.toAll()

10 In Express.js, what is 'middleware'?

A. Functions that have access to the request and response objects
B. A front-end framework
C. A database driver
D. A CSS preprocessor

11 What is the purpose of the 'next' function in Express middleware?

A. To redirect the user
B. To restart the server
C. To pass control to the next middleware function
D. To send the response immediately

12 Which Express method is used to mount middleware functions at a specific path?

A. app.mount()
B. app.bind()
C. app.middleware()
D. app.use()

13 What does app.all('/api/*', ...) do?

A. Handles only GET requests for /api/
B. Handles all HTTP methods (GET, POST, etc.) for routes starting with /api/
C. Handles requests from all IP addresses
D. Handles only POST requests for /api/

14 What is the primary purpose of the cookie-parser middleware?

A. To populate req.cookies with an object keyed by the cookie names
B. To delete all cookies on the client
C. To eat cookies
D. To encrypt cookies automatically

15 Where does cookie-session store the session data?

A. On the server's database
B. In the server's memory
C. On the client-side within the cookie itself
D. In a Redis cache

16 Where does express-session store the session data by default?

A. In the URL
B. In server-side memory (MemoryStore)
C. In a text file
D. On the client browser

17 Which option allows Socket.IO clients to join a specific channel or 'room'?

A. socket.join('room1')
B. io.join('room1')
C. socket.room('room1')
D. socket.enter('room1')

18 In Socket.IO, how do you send a message only to clients in a specific room?

A. io.in('roomName').broadcast(data)
B. io.emit('roomName', data)
C. socket.send('roomName', data)
D. io.to('roomName').emit('event', data)

19 What argument is required to initialize cookie-parser if you want to use signed cookies?

A. A secret string
B. A database connection
C. A file path
D. The session ID

20 When using express-session, which property is added to the request object?

A. req.cookies
B. req.session
C. req.storage
D. req.cache

21 Which express-session option forces the session to be saved back to the store, even if it wasn't modified?

A. cookie
B. saveUninitialized
C. resave
D. secret

22 In middleware, what happens if you call next() with an error argument, like next(new Error('Fail'))?

A. It skips to the next error-handling middleware
B. It skips to the next non-error middleware
C. The server crashes
D. It reloads the page

23 What is the signature of a standard Express error-handling middleware function?

A. (req, res, next)
B. (err, req, res, next)
C. (err, req, res)
D. (req, res)

24 To serve static files such as images or CSS files in Express, which built-in middleware is used?

A. express.assets()
B. express.public()
C. express.static()
D. express.files()

25 Which library is the client-side counterpart to the Node.js 'socket.io' package?

A. socket.io-client
B. websocket.js
C. socket-client.js
D. ws-client

26 In a WebSocket 'message' event, the data received is typically:

A. Always a JSON object
B. Always a String or Buffer
C. Always an Array
D. Always an Integer

27 Which cookie-session option helps prevent Cross-Site Scripting (XSS) attacks by preventing client-side scripts from accessing the cookie?

A. httpOnly: true
B. signed: true
C. maxAge: 1000
D. secure: true

28 If you want middleware to run for every request to the application, how should you mount it?

A. app.use('/home', middleware)
B. app.get(middleware)
C. app.use(middleware)
D. app.post(middleware)

29 What is the default name of the cookie used by express-session to store the session ID?

A. session_id
B. jsessionid
C. express.sid
D. connect.sid

30 In Socket.IO, what is a 'Namespace'?

A. A variable name
B. A database table
C. A type of error
D. A separate communication channel allowing multiplexing over a single connection

31 How do you access signed cookies in Express if cookie-parser is set up with a secret?

A. req.secureCookies
B. req.cookies
C. req.signedCookies
D. req.secretCookies

32 Which method removes a specific session in express-session?

A. req.session.delete()
B. req.session.destroy()
C. req.session.remove()
D. req.session.clear()

33 When using app.use(bodyParser.json()), what does this middleware do?

A. Encrypts JSON data
B. Parses incoming requests with JSON payloads
C. Validates JSON syntax only
D. Sends JSON responses

34 In Socket.IO, what does the volatile flag do? e.g., socket.volatile.emit(...)

A. Deletes the message immediately after sending
B. Sends the message but allows it to be lost if the client is not ready
C. Ensures the message is encrypted
D. Sends the message repeatedly until acknowledged

35 What is the main disadvantage of cookie-session compared to express-session?

A. It cannot store large amounts of data (limited by cookie size)
B. It requires a database
C. It only works with HTTPS
D. It is slower

36 Which event is fired in Socket.IO when a client disconnects?

A. stop
B. halt
C. disconnect
D. end

37 How can you limit middleware to a specific HTTP verb (e.g., POST) for a specific path?

A. app.post('/path', middleware)
B. app.all()
C. app.route()
D. app.use()

38 What is a 'room' in Socket.IO primarily used for?

A. Storing data permanently
B. Partitioning connected clients into groups
C. Logging errors
D. Authentication

39 If you want to persist login state across server restarts effectively, which session store should you use with express-session?

A. An array variable
B. A compatible store like Redis or MongoDB
C. MemoryStore
D. A text file

40 What is the output of typeof req.session inside a route handler when using express-session?

A. string
B. object
C. function
D. undefined

41 Which middleware would you use to log details of every incoming request (method, URL, etc.)?

A. cookie-parser
B. morgan
C. helmet
D. express-session

42 In a WebSocket connection, what property indicates the current state (connecting, open, closing, closed)?

A. socket.state
B. socket.connStatus
C. socket.status
D. socket.readyState

43 When initializing express-session, what does the saveUninitialized: false option do?

A. It deletes the session immediately
B. It prevents saving a session to the store if it is new but not modified
C. It saves empty sessions to the store
D. It saves the session without a cookie

44 Which function allows multiple middleware functions to be applied to a single route?

A. Using app.double()
B. Creating a loop
C. Passing them as comma-separated arguments to the route method
D. They cannot be chained

45 In Socket.IO, socket.id represents:

A. A unique identifier for the socket session
B. The port number
C. The IP address
D. The user's database ID

46 If you wish to send binary data (like an image) via ws library, what type of data should you pass to .send()?

A. A Boolean
B. An Object
C. A Buffer or ArrayBuffer
D. A JSON string

47 What is the purpose of the 'secret' used in session middleware?

A. To encrypt the database connection
B. To authenticate users
C. To hide the server IP
D. To sign the session ID cookie to prevent tampering

48 Can middleware modify the req and res objects?

A. Only res can be modified
B. Only req can be modified
C. Yes, middleware can add properties or methods to them
D. No, they are read-only

49 In a Chat Server, why would you store socket.id mapped to a username?

A. To increase download speed
B. To use less memory
C. To prevent the user from logging out
D. To enable private messaging functionality

50 What happens if you attempt to use req.body without installing and using a body-parsing middleware (like express.json())?

A. It will work automatically
B. The server will crash
C. It will contain the raw stream
D. req.body will be undefined